微信公众号:"算法与编程之美",欢迎关注,及时了解更多此系列文章
简介
Cookie是一个简单的保存在本地的文本文件,这个文件与特定的Web文档关联在一起,保存了一些该浏览器访问这个Web文档时的信息,当再次访问的时候这些信息可以继续拿出来使用。一般来说,Cookie的大小不超过4kb。由名称、值和其他几个用于控制Cookie有效期、安全性、使用范围的可选属性组成。
其实Session和Cookie差不多,都是为了保存用户相关的信息,但是Session是储存在服务器端,而Cookie是储存在浏览器的。
具体操作
1.操作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时就能删除掉刚刚设置好的Cookieusername,如图所示:
图2 删除Cookie
设置Cookie的这个方法有几个属性,可以根据情况进行增添。
·key:键
·value:值
·max_age:设置过期时间(秒)
·expires:设置过期时间,时间戳的形式(1970离现在的时间)
·path:当前主域名
·domain:子域名
2.操作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() |
END
编 辑 | 王楠岚
责 编 | 刘玉江
where2go 团队
微信号:算法与编程之美
长按识别二维码关注我们!
“写留言”发表评论,期待您的参与!