cookie
服务端保存在客户端浏览器上的信息都可以称之为cookie
它的表现形式一般都是k:v键值对(可以有多个)
session
数据是保存在服务端的并且它的表现形式一般也是k:v键值对(可以有多个)
总结:
1.cookie就是保存在客户端浏览器上的信息
2.session就是保存在服务端上的信息
3.session是基于cookie工作的(其实大部分的保存用户状态的操作都需要使用到cookie)
Cookie操作
# 如果你想要操作cookie,你就不得不利用obj对象
obj1 = HttpResponse()
return obj1
obj2 = render()
return obj2
obj3 = redirect()
return obj3
"""
设置cookie
obj.set_cookie(key,value)
eg:obj.set_cookie('username', 'tiger')
获取cookie
request.COOKIES.get(key)
eg:request.COOKIES.get('username')
设置cookie超时时间
max_age
expires
两者都是设置超时时间的 并且都是以秒为单位
需要注意的是 针对IE浏览器需要使用expires
eg:obj.set_cookie('username', 'tiger', max_age=60)
主动删除cookie(注销功能)
obj.delete_cookie(key)
eg:obj.delete_cookie('username')
"""
session操作(按照字典操作即可)
"""
session数据是保存在服务端的(存在哪? ),给客户端返回的是一个随机字符串
sessionid:随机字符串
存在服务端哪?
1.在默认情况下操作session的时候需要django默认的一张django_session表
数据库迁移命令
django会自己创建很多表 django_session就是其中的一张
django默认session的过期时间是14天
但是你也可以人为的修改它
设置session
request.session['key'] = value
获取session
request.session.get('key')
设置过期时间
request.session.set_expiry()
括号内可以放四种类型的参数
1.整数 多少秒
2.日期对象 到指定日期就失效
3.0 一旦当前浏览器窗口关闭立刻失效
4.不写 失效时间就取决于django内部全局session默认的失效时间14天
清除session
request.session.delete() # 只删服务端的 客户端的不删
request.session.flush() # 浏览器和服务端都清空(推荐使用)
"""
def set_session(request):
request.session['hobby'] = 'study'
"""
内部发生了哪些事
1.django内部会自动帮你生成一个随机字符串
2.django内部自动将随机字符串和对应的数据存储到django_session表中
2.1先在内存中产生操作数据的缓存
2.2在响应结果django中间件的时候才真正的操作数据库
3.将产生的随机字符串返回给客户端浏览器保存
"""
return HttpResponse('好好学习 天天向上!')
def get_session(request):
print(request.session.get('hobby'))
"""
内部发送了那些事
1.自动从浏览器请求中获取sessionid对应的随机字符串
2.拿着该随机字符串去django_session表中查找对应的数据
3.
如果比对上了 则将对应的数据取出并以字典的形式封装到request.session中
如果比对不上 则request.session.get()返回的是None
"""
return HttpResponse('哈哈哈!')
标签:浏览器,request,django,session,cookie,服务端
From: https://www.cnblogs.com/piggthird/p/17780238.html