cookie与session如何在Django中使用

这篇文章给大家介绍cookie与session如何在Django中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

一、引子

http协议是无状态的,就是它不会记录请求和响应的任何信息,比如你访问一个服务器的一个网页时,先要你登录一下,然后进入网页,但当你要进入这个服务器的另一个网页时,它照常不会知道刚才你已经登录过了,又要让你登录一下,就是一个bug。但是,你说你每次上网的时候,只需要登录一下就行了,并没有我说的让你每次都登录,这是会话路径技术帮你记录了你的登录信息,现在我们们就来讲讲Django的会话路径技术cookie和session,实现会话追踪。

二、cookie

cookie是key-value结构,类似于一个字典。随着服务器的响应发送给客户端浏览器,然后客户端浏览器会把cookie保存起来,当下一次再访问服务器时把cookie再发送给服务器。

cookie与session如何在Django中使用

语法:

response.set_cookie()#这是设置cookie值
request.COOKIES#取cookie值

基于cookie的登录页面和主页面

deflogin(request):#登录视图
ifrequest.method=="GET":
returnrender(request,"login.html")
else:
user=request.POST.get("user")
pwd=request.POST.get("pwd")

user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first()
ifuser_obj:用户验证成功后,设置cookie值,响应给浏览器,浏览器会保存cookie
#obj=HttpResponse("登录成功!")
obj=redirect("/index/")
obj.set_cookie("is_login",True,20)
obj.set_cookie("username",user)
returnobj
returnHttpResponse("Error!")

defindex(request):#进入主页面视图

print("request.COOKIES",request.COOKIES)
is_login=request.COOKIES.get("is_login")#首先取到cookie值,对值进行判断
username=request.COOKIES.get("username")

ifnotis_login:#值为空时,执行这里,说明之前没有登录过,重定向到登录页面
returnredirect("/login/")

returnrender(request,"index.html",{"username":username})

三、session

上面的cookie是浏览器端保存的,现在的session是基于cookie的,但是保存在服务器端的技术,服务器在运行时可以为每一个访问的浏览器设置一个session,然后保存在Django下的Django_session表中。

cookie与session如何在Django中使用

语法:

request.session["k1"]="v1"设置session值
request.session.get("k1")取session值
request.session.flush()清空session值

基于session的登录页面和主页面的访问

deflogin(request):
ifrequest.method=="GET":
returnrender(request,"login.html")
else:
user=request.POST.get("user")
pwd=request.POST.get("pwd")
user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first()
ifuser_obj:
request.session["is_login"]=True
request.session["username"]=user
returnredirect("/index/")
returnHttpResponse("Error!")defindex(request):
is_login=request.session.get("is_login")
username=request.session.get("username")ifnotis_login:
returnredirect("/login/")
returnrender(request,"index.html",{"username":username})

四、图片验证码的实现

HTML文件:登录页面

<!DOCTYPEhtml>
<htmllang="en">
<head>
<metacharset="UTF-8">
<title>Title</title>
<linkrel="stylesheet"href="/static/css/bootstrap.css"rel="externalnofollow">
<scriptsrc="/static/jquery-3.3.1.js"></script>
<scriptsrc="/static/js/bootstrap.js"></script>
</head>
<body>
{%csrf_token%}
<divclass="container">
<divclass="row">
<divclass="col-md-5">
<div>登录页面</div>
<divclass="form-group">
名字<inputtype="text"name="user"class="form-control">
</div>
<divclass="form-group">
密码<inputtype="password"name="pwd"class="form-control">
</div>
<divclass="rowform-group">
<divclass="col-md-6">验证码<inputtype="text"name="yan"class="form-control"></div>
<divclass="col-md-6"><imgsrc="/img_drow/"alt=""width="200"height="40"></div>
</div>
<buttonclass="login">登录</button>
<p></p>
</div>
</div>
</div>
<script>
$('.login').click(function(){
varname=$('[name="user"]').val();
varpw=$('[name="pwd"]').val();
varyan=$('[name="yan"]').val();
$.ajax({
url:'/login/',
type:'post',
data:{csrfmiddlewaretoken:$('[name="csrfmiddlewaretoken"]').val(),user:name,pwd:pw,yan:yan},
success:function(data){
if(data=='200'){
location.href='/books/'
}
elseif(data=='100'){
$('p').html('用户名或密码输入错误')
}
else{
$('p').html('验证码错误');
varnum=Math.random();
$('img').attr('src','/img_drow?'+num)
}
}
})
});
$('img').click(function(){
varnum=Math.random();
$(this).attr('src','/img_drow?'+num)
})
</script>
</body>
</html>

views:

产生随机图片验证的视图函数
importrandom
fromPILimportImage,ImageDraw,ImageFont
fromioimportBytesIO
defget_random_color():
returnrandom.randint(0,255),random.randint(0,255),random.randint(0,255)
defimg_drow(request):
img=Image.new('RGB',(200,40),get_random_color())
draw=ImageDraw.Draw(img)
font=ImageFont.truetype('static/fonts/kumo.ttf',34)
keep_str=''
foriinrange(5):
num=str(random.randint(0,9))
lower=chr(random.randint(65,90))
upper=chr(random.randint(97,122))
random_char=random.choice([num,lower,upper])
draw.text((i*30+50,0),random_char,get_random_color(),font=font)
keep_str+=random_char
width=200
height=40
foriinrange(10):
x1=random.randint(0,width)
x2=random.randint(0,width)
y1=random.randint(0,height)
y2=random.randint(0,height)
draw.line((x1,y1,x2,y2),fill=get_random_color())
foriinrange(10):
draw.point([random.randint(0,width),random.randint(0,height)],fill=get_random_color())
x=random.randint(0,width)
y=random.randint(0,height)
draw.arc((x,y,x+4,y+4),0,90,fill=get_random_color())
request.session['keep_str']=keep_str
f=BytesIO()
img.save(f,'png')
data=f.getvalue()
returnHttpResponse(data)
deflogin(request):
ifrequest.method=='GET':
returnrender(request,'login.html')
else:
yan=request.POST.get('yan')
ifyan.upper()==request.session.get('keep_str').upper():
user=request.POST.get('user')
pwd=request.POST.get('pwd')
obj=UserInfo.objects.filter(name=user,pwd=pwd).first()
ifobj:
request.session['state']=True
request.session['user']=user
returnHttpResponse('200')
else:
returnHttpResponse('100')
else:
returnHttpResponse('300')

关于cookie与session如何在Django中使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

发布于 2021-03-26 01:48:56
收藏
分享
海报
0 条评论
158
上一篇:在小程序中使用this.setData时需要注意哪些事项 下一篇:如何在node.js中使用Express服务器
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码