cookie和session结合使用:
web
开发发展至今,cookie
和session
的使用已经出现了一些非常成熟的方案。在如今的市场或者企业里,一般有两种存储方式:- 存储在服务端:通过
cookie
存储一个session_id
,然后具体的数据则是保存在session
中。如果用户已经登录,则服务器会在cookie
中保存一个session_id
,下次再次请求的时候,会把该session_id
携带上来,服务器根据session_id
在session
库中获取用户的session
数据。就能知道该用户到底是谁,以及之前保存的一些状态信息。这种专业术语叫做server side session
。 - 将
session
数据加密,然后存储在cookie
中。这种专业术语叫做client side session
。flask
采用的就是这种方式,但是也可以替换成其他形式。
- 存储在服务端:通过
session:Flask
中的session
是通过from flask import session
。然后添加值key和value进去即可。并且,Flask
中的session
机制是将session
信息加密,然后存储在cookie
中。专业术语叫做client side session
。
2、Flask生成SECRET_KEY(密钥)的一种简单方法
>>> import os
>>> os.urandom(24)
'\xca\x0c\x86\x04\x98@\x02b\x1b7\x8c\x88]\x1b\xd7"+\xe6px@\xc3#\\'
设置秘钥:
Session 也可以设置过期时间:
Session使用:
往session 里面添加数据。此时session是相当于一个字典(dict)。
然后获取session 里面的值,看看是否存在。
那么如何删除session呢?可以直接使用session.pop('key',None) 即:
session.pop('name',None)
如果要删除session中所有数据使用:clear()即:
session.clear()