加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

Django cookie和session

发布时间:2020-12-15 17:13:38 所属栏目:大数据 来源:网络整理
导读:1、cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生。 cookie的工作原理是:由服务器产生内容,浏览器收到请求后保存在本地;当浏览器再次访问时,浏览器会自动带上cookie

1、cookie不属于http协议范围,由于http协议无法保持状态,但实际情况,我们却又需要“保持状态”,因此cookie就是在这样一个场景下诞生。

cookie的工作原理是:由服务器产生内容,浏览器收到请求后保存在本地;当浏览器再次访问时,浏览器会自动带上cookie,这样服务器就能通过cookie的内容来判断这个是“谁”了。

2、cookie虽然在一定程度上解决了“保持状态”的需求,但是由于cookie本身最大支持4096字节,以及cookie本身保存在客户端,可能被拦截或窃取,因此就需要有一种新的东西,它能支持更多的字节,并且他保存在服务器,有较高的安全性。这就是session。

问题来了,基于http协议的无状态特征,服务器根本就不知道访问者是“谁”。那么上述的cookie就起到桥接的作用。

我们可以给每个客户端的cookie分配一个唯一的id,这样用户在访问时,通过cookie,服务器就知道来的人是“谁”。然后我们再根据不同的cookie的id,在服务器上保存一段时间的私密资料,如“账号密码”等等。

3、总结而言:cookie弥补了http无状态的不足,让服务器知道来的人是“谁”;但是cookie以文本的形式保存在本地,自身安全性较差;所以我们就通过cookie识别不同的用户,对应的在session里保存私密的信息以及超过4096字节的文本。


获取cookie和设置cookie代码示例:

def?login(req):
????#?获取cookie
????print("cookie",req.COOKIES)
????if?req.method?==?'POST':
????????name?=?req.POST.get('user')
????????pwd?=?req.POST.get('password')
????????if?name?==?'admin'?and?pwd?==?'123123':
????????????ret?=?redirect('/index/')
????????????#?为cookie设置值,cookie有效时间为一个小时
????????????ret.set_cookie('bilibi','acfine',max_age=3600,????????????expires=datetime.datetime.utcnow()+datetime.timedelta(5))
????????????#?expires?是cookie有效期,意思cookie有效期是当前标准时间加5天
????????????return?ret
????return?render(req,?'login.html')
????
????
def?index(req):
????#?cookie
????user?=?'admin'
????if?req.COOKIES.get('bilibi',?None)?==?'acfine':
????????return?render(req,?'index.html',?locals())
????else:
????????return?redirect('login.html')

session无提示解决方法:

????1、找到setting.py文件

? ? 2、找到MIDDLEWARE,然后替换为MIDDLEWARE_CLASSES

session方法:

????session.set_expirty()????????设置session有效期


获取session和设置session代码示例:

def?login(req):
????print('session',?req.session)
????if?req.method?==?'POST':
????????name?=?req.POST.get('user')
????????pwd?=?req.POST.get('password')
????????if?name?==?'admin'?and?pwd?==?'123123':
????????????#?session?和?cookie
????????????req.session['is_login']?=?True
????????????req.session['user']?=?name
????????????req.session.set_expirty(3600)
????????????#?session有效期是一小时
????????????return?redirect('/index/')

????return?render(req,?'login.html')
????

????
def?index(req):
????#?cookie?和?sesssion
????if?req.session.get('is_login'):
????????name?=?req.session.get('user')
????????return?render(req,?'index.html')
????else:
????????return?redirect('/login/')


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读