cookie与session如何在Django中使用
这篇文章给大家介绍cookie与session如何在Django中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
一、引子
http协议是无状态的,就是它不会记录请求和响应的任何信息,比如你访问一个服务器的一个网页时,先要你登录一下,然后进入网页,但当你要进入这个服务器的另一个网页时,它照常不会知道刚才你已经登录过了,又要让你登录一下,就是一个bug。但是,你说你每次上网的时候,只需要登录一下就行了,并没有我说的让你每次都登录,这是会话路径技术帮你记录了你的登录信息,现在我们们就来讲讲Django的会话路径技术cookie和session,实现会话追踪。
二、cookie
cookie是key-value结构,类似于一个字典。随着服务器的响应发送给客户端浏览器,然后客户端浏览器会把cookie保存起来,当下一次再访问服务器时把cookie再发送给服务器。
语法:
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表中。
语法:
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中使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
推荐阅读
-
浅析Django接口版本控制
-
Django+Celery实现定时任务的示例
-
Python(django中如何使用restful框架)
-
Django实现drf搜索过滤和排序过滤
-
Django中怎么将ValuesQuerySet转换成json
今天就跟大家聊聊有关Django中怎么将ValuesQuerySet转换成json,可能很多人都不太了解,为了让大家更加了解,小编...
-
Django分页器的使用方法
这篇文章主要介绍了Django分页器的使用方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面...
-
Python Django搭建文件下载服务器的实现shili
-
在Django中如何使用MQTT的方法
这篇文章主要介绍了在Django中如何使用MQTT的方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有...
-
Django开发RESTful API怎么实现增删改查
-
Django如何显示可视化图表的实践