发布时间:2019-08-08 07:45:16编辑:auto阅读(1416)
由于http是无状态的,很多网站需要识别登录进来的用户身份,以备下次直接登录或者区分是哪个用户登录的,这样可以根据不同的用户展示不同的信息,这样就需要一种技术来保存用户的状态,这样会话技术应运而生!
当用户第一次登录成功后,服务器会通过Httpresponse/redirect/render获取的对象通过调用set_cookie,设置cookie,返回给浏览器,并且保存在浏览器端,当下次访问时浏览器会自动携带cookie完成对服务器的访问;
对服务器进行访问时服务器需要获取id,这个id就是sessionId,当然id名字可以自动设置,如果有则在相应的数据库进行查找相应的用户信息,如果没有该id,则服务器会创建相应的session,并返回给浏览器,保存在浏览器端,下次访问时就会根据这个session的内容去查找相应的信息;
######用户校验成功#######
request.session['isLogin'] = True
request.session['userName'] = user_name
return redirect(...)
当设置session时,django会做两件事情:
1.首先产生一个随机字符串;
2.将session所设置的键对应的值添加到session字典中,并和之前产生的随机字符串组成一个新的字典,形如{‘随机字符串’:{'isLogin':True,'userName':'sheldon'}},并默认保存到数据库中,然后在return时将{sessionId:'随机字符串'}和页面内容一起返回到浏览器;
当获取session的值时:
当用户再次访问服务器时,服务器会检查有没有携带过来的sessionId,根据对应的随机字符串去数据库查找对应的用户信息;
request.session.flush()
会将数据库中的一条表记录删除;
del request.session['isLogin']
删除某个名值对,这样也能达到校验效果;
上一篇: Python获取本机所有IP地址
下一篇: Python 文本和数字相等判断
47496
45799
36797
34327
28970
25600
24445
19613
19113
17635
5469°
6051°
5573°
5640°
6575°
5378°
5380°
5887°
5858°
7174°