赞
踩
Flask设置Cookie和Session
1 简介
Cookie是一个保存在本地的简单的文本文件,这个文件与特定的Web文档关联在一起,保存了一些该浏览器访问这个Web文档时的信息,当再次访问的时候这些信息可以继续拿出来使用。一般来说,Cookie的大小不超过4kb。由名称,值和其他几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。
Session其实和Cookie差不多,都是为了保存用户相关的信息,但是Session是储存在服务器端,而Cookie是储存在浏览器的。
2 操作Cookie
通过在flask.Response对象上的set_cookie方法,具体代码如下:
from flask import Flask, Response, request app = Flask(__name__) @app.route('/') def index(): resp = Response("设置Cookie") resp.set_cookie('username', 'liu',) return resp if __name__ == "__main__": |
当浏览器访问的时候就能查看到我们刚刚设置好的Cookie:
图1 浏览器查看Cookie
还可以通过在flask.Response对象上的delete_cookie方法来删除Cookie,具体代码如下:
@app.route('/del') def delete(): resp = Response("删除Cookie") resp.delete_cookie('username') return resp |
这样通过访问/del时就能删除掉刚刚设置好的Cookie username,如图所示:
图2 删除Cookie
设置Cookie的这个方法有几个属性,可以根据情况进行增添。
·key:键
·value:值
·max_age:设置过期时间(秒)
·expires:设置过期时间,时间戳的形式(1970离现在的时间)
·path:当前主域名
·domain:子域名
3 操作Session
·设置Session,通过flask.seesion即可,跟字典是一样的操作。
Session[‘username’] = ‘liu’
·获取Session,也是跟字典是一样的,session.get(‘username’)
·删除Session,通过session.pop(‘liu’)删除指定的值,通过session.clear()删除所有的值。
·有效期,如果没有设置的话,就是关闭浏览器后过期。如果设置session.parmanent=True,那么就会默认31天后过期。如果不想在31天后过期,那么可以设置app.config['PERMANENT_SESSION_LIFETIME']= timedelta(hour=2),可以指定多久后过期(比如:2小时)。
代码如下:
from flask import Flask, session import os app = Flask(__name__) app.config['SECRET_KEY'] = os.urandom(24)
@app.route('/') def index(): session['username'] = 'liu' return '设置Session'
@app.route('/get_session') def get_session(): username = session.get('username') #获取session if username is None: return 'Null' return username
@app.route('/del_session') def del_session(): session.pop('username') return "删除Session"
if __name__ == "__main__": app.run() |
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。