Flacon - Sessions

Comme le cookie, les données de session sont stockées sur le client. La session est l'intervalle de temps pendant lequel un client se connecte à un serveur et se déconnecte. Les données, qui doivent être conservées tout au long de cette session, sont stockées dans le navigateur client.

Une session avec chaque client se voit attribuer un Session ID. Les données de session sont stockées au-dessus des cookies et le serveur les signe de manière cryptographique. Pour ce chiffrement, une application Flask a besoin d'unSECRET_KEY.

L'objet session est également un objet dictionnaire contenant des paires clé-valeur de variables de session et les valeurs associées.

Par exemple, pour définir un ‘username’ variable de session utiliser l'instruction -

Session[‘username’] = ’admin’

Pour libérer une variable de session, utilisez pop() méthode.

session.pop('username', None)

Le code suivant est une simple démonstration des travaux de session dans Flask. URL‘/’ invite simplement l'utilisateur à se connecter, en tant que variable de session ‘username’ n'est pas défini.

@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>"

Lorsque l'utilisateur navigue vers '/ login', la fonction de vue login (), car elle est appelée via la méthode GET, ouvre un formulaire de connexion.

Un formulaire est renvoyé à ‘/login’et maintenant la variable de session est définie. L'application est redirigée vers‘/’. Cette variable de session de temps‘username’ est trouvé.

@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>
	
   '''

L'application contient également un logout() fonction d'affichage, qui apparaît ‘username’variable de session. Par conséquent,‘/’ L'URL affiche à nouveau la page d'ouverture.

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

Exécutez l'application et visitez la page d'accueil. (Assurez-vous de définirsecret_key de l'application)

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

La sortie sera affichée comme indiqué ci-dessous. Cliquer sur le lien“click here to log in”.

Le lien sera dirigé vers un autre écran. Tapez «admin».

L'écran vous montrera le message, ‘Logged in as admin’.