फ्लास्क - सत्र

कुकी की तरह, सत्र डेटा क्लाइंट पर संग्रहीत किया जाता है। सत्र वह समय अंतराल है जब कोई क्लाइंट किसी सर्वर में लॉग इन करता है और इससे बाहर निकलता है। डेटा, जिसे इस सत्र में आयोजित करने की आवश्यकता है, क्लाइंट ब्राउज़र में संग्रहीत है।

प्रत्येक ग्राहक के साथ एक सत्र सौंपा गया है Session ID। सत्र डेटा कुकीज़ के शीर्ष पर संग्रहीत किया जाता है और सर्वर उन्हें क्रिप्टोग्राफिक रूप से हस्ताक्षरित करता है। इस एन्क्रिप्शन के लिए, एक फ्लास्क एप्लिकेशन को एक परिभाषित की आवश्यकता होती हैSECRET_KEY

सत्र वस्तु भी एक शब्दकोश वस्तु है जिसमें सत्र चर और संबंधित मूल्यों के प्रमुख-मूल्य जोड़े हैं।

उदाहरण के लिए, एक सेट करने के लिए ‘username’ सत्र चर विवरण का उपयोग करें -

Session[‘username’] = ’admin’

एक सत्र चर उपयोग जारी करने के लिए pop() तरीका।

session.pop('username', None)

निम्न कोड फ्लास्क में सत्र कार्यों का एक सरल प्रदर्शन है। यूआरएल‘/’ बस सत्र चर के रूप में उपयोगकर्ता को लॉग इन करने का संकेत देता है ‘username’ सेट नहीं है।

@app.route('/')
def index():
   if 'username' in session:
      username = session['username']
         return 'Logged in as ' + username + '<br>' + \
         "<b><a href = '/logout'>click here to log out</a></b>"
   return "You are not logged in <br><a href = '/login'></b>" + \
      "click here to log in</b></a>"

जैसा कि उपयोगकर्ता लॉगिन () व्यू फंक्शन को '/' लॉगिन करने के लिए करता है, क्योंकि इसे GET विधि के माध्यम से कहा जाता है, एक लॉगिन फ़ॉर्म खोलता है।

एक फॉर्म वापस पोस्ट किया जाता है ‘/login’और अब सत्र चर सेट है। एप्लिकेशन को पुनर्निर्देशित किया जाता है‘/’। इस बार सत्र चर‘username’ पाया जाता है।

@app.route('/login', methods = ['GET', 'POST'])
def login():
   if request.method == 'POST':
      session['username'] = request.form['username']
      return redirect(url_for('index'))
   return '''
	
   <form action = "" method = "post">
      <p><input type = text name = username/></p>
      <p<<input type = submit value = Login/></p>
   </form>
	
   '''

आवेदन भी एक logout() फ़ंक्शन देखें, जो पॉप आउट करता है ‘username’सत्र चर। इसलिये,‘/’ URL फिर से शुरुआती पृष्ठ दिखाता है।

@app.route('/logout')
def logout():
   # remove the username from the session if it is there
   session.pop('username', None)
   return redirect(url_for('index'))

एप्लिकेशन चलाएं और होमपेज पर जाएं। (सेट करने के लिए सुनिश्चित करेंsecret_key आवेदन का)

from flask import Flask, session, redirect, url_for, escape, request
app = Flask(__name__)
app.secret_key = 'any random string’

आउटपुट नीचे दिखाए अनुसार प्रदर्शित किया जाएगा। लिंक पर क्लिक करें“click here to log in”

लिंक को दूसरी स्क्रीन पर निर्देशित किया जाएगा। 'व्यवस्थापक' लिखें।

स्क्रीन आपको संदेश दिखाएगा, ‘Logged in as admin’