一、Session的概念
cookie
是在浏览器端保存键值对数据,而session
是在服务器端保存键值对数据session
的使用依赖cookie:
在使用Session后,会在Cookie中存储一个sessionid的数据,每次请求时浏览器都会将这个数据发给服务器,服务器在接收到sessionid后,会根据这个值找出这个请求者的Session。
二、Django中session
的使用
- session键值对数据保存
session
数据默认保存在django项目的一张数据库表中(表名为:django_session
),保存格式如下:
三、数据操作:
- 以键值对的格式写session
request.session['键']=值
- 根据键读取值
request.session.get('键',默认值)
# 或者
request.session['键']
- 清除所有session,在存储中删除值的部分
request.session.clear()
- 清除session数据,在存储中删除session的整条数据
request.session.flush()
- 删除session中的指定键及值,在存储中只删除某个键及对应的值
del request.session['键']
- 设置session数据有效时间; 如果不设置,默认过期时间为两周
request.session.set_expiry(value)
- 如果value是一个整数,则 session数据 将在value秒没有活动后过期。
- 如果value为None,那么会话永不过期。
- 如果value为0,那么用户会话的Cookie将在用户的浏览器关闭时过期。