如何通过Django操作session
# session操作session数据是保存在服务端的,给客户端返回的是一个随机字符串
浏览器保存形式为session_id:随机字符串(键) session数据表中的形式为随机字符串(键):随机字符串(数据)
1、在默认情况下操作session的时候需要django默认一张django_session表
数据库迁移命令的时候:makemigrirations migrate
django会自动创建很多表 django_session就是其中一张[设置session]
request.session['key'] =value
def set_session(request):
request.set_session['hobby']='girl'
"""
内部发生了哪些事情:
1、django内部会随机生成一个字符串(一开自己设置的键)
2、django内部会自动将随机字符串和对应的数据存储到django_session表中
a:先在内存中产生操作数据的缓存
b:在响应结果django中间件的时候才真正的操作数据库
3、将产生的随机字符串(键)返回给客户端浏览器保存
"""
return HttpResponse('嘿嘿嘿’)[获取session] 和cookie差不多
request.session.get('key')
def get_session(request):
request.get_session.get('hobby')
"""
内部发发生了那些事情?
1、自动从浏览器请求中获取session_id对应的字符串
2、拿着该字符串去django表中查找相对应的数据
3、如果比对上了,则将数据取出来并以字典的形式封装到request.session中
如果比对不上,则request.session.get()返回为None
"""
return HttpResponse('嘿嘿嘿’)[设置过期时间]
与cookie不同cookie在set_cookie(key=value,max_age=5)就可以了request.session.set_expiry()
括号内可以放四种类型的参数
1、直接放整数 多少秒[常用]
2、日期对象 到指定日期就失效[常用]
3、0 一旦当前浏览器窗口关闭就立刻失效[这个策略暂时没有了]
4、不写 就取决于django内部全局session默认时间
[清除session]
request.session.delete() #只删服务端的 客户端的不删
request.session.flush() # 浏览器和服务端都清空[推荐使用]
def del_session(request):
request.session.flush()
return HttpResponse('删除了')django_session表中的数据条数取决于浏览器
(当session过期的时候可能会出现多条数据对应一个浏览器,但是该情况不会持续很久,内部会自动清除过期数据,也可以通过代码清楚)
[同一个计算机同一个浏览器只会有一条数据生效,谷歌和360,IE在一起会产生多个,]
主要是节省服务端资源django默认session过期时间是14天
但是你可以人为的修改它
是保存在服务端的,但是session的保存位置可以有多种选择]
1、MySQL
2、文件里面
3、缓存文件redis
4、memcache
。。。。
页:
[1]