這篇文章給大家介紹cookie與session如何在Django中使用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。
專業(yè)成都網(wǎng)站建設(shè)公司,做排名好的好網(wǎng)站,排在同行前面,為您帶來客戶和效益!成都創(chuàng)新互聯(lián)公司為您提供成都網(wǎng)站建設(shè),五站合一網(wǎng)站設(shè)計(jì)制作,服務(wù)好的網(wǎng)站設(shè)計(jì)公司,成都網(wǎng)站制作、做網(wǎng)站負(fù)責(zé)任的成都網(wǎng)站制作公司!一、引子
http協(xié)議是無狀態(tài)的,就是它不會(huì)記錄請(qǐng)求和響應(yīng)的任何信息,比如你訪問一個(gè)服務(wù)器的一個(gè)網(wǎng)頁時(shí),先要你登錄一下,然后進(jìn)入網(wǎng)頁,但當(dāng)你要進(jìn)入這個(gè)服務(wù)器的另一個(gè)網(wǎng)頁時(shí),它照常不會(huì)知道剛才你已經(jīng)登錄過了,又要讓你登錄一下,就是一個(gè)bug。但是,你說你每次上網(wǎng)的時(shí)候,只需要登錄一下就行了,并沒有我說的讓你每次都登錄,這是會(huì)話路徑技術(shù)幫你記錄了你的登錄信息,現(xiàn)在我們們就來講講Django的會(huì)話路徑技術(shù)cookie和session,實(shí)現(xiàn)會(huì)話追蹤。
二、cookie
cookie是key-value結(jié)構(gòu),類似于一個(gè)字典。隨著服務(wù)器的響應(yīng)發(fā)送給客戶端瀏覽器,然后客戶端瀏覽器會(huì)把cookie保存起來,當(dāng)下一次再訪問服務(wù)器時(shí)把cookie再發(fā)送給服務(wù)器。
語法:
response.set_cookie() #這是設(shè)置cookie值 request.COOKIES #取cookie值
基于cookie的登錄頁面和主頁面
def login(request): #登錄視圖 if request.method=="GET": return render(request,"login.html") else: user = request.POST.get("user") pwd = request.POST.get("pwd") user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first() if user_obj: 用戶驗(yàn)證成功后,設(shè)置cookie值,響應(yīng)給瀏覽器,瀏覽器會(huì)保存cookie # obj=HttpResponse("登錄成功!") obj=redirect("/index/") obj.set_cookie("is_login",True,20) obj.set_cookie("username",user) return obj return HttpResponse("Error!") def index(request): #進(jìn)入主頁面視圖 print("request.COOKIES",request.COOKIES) is_login=request.COOKIES.get("is_login") #首先取到cookie值,對(duì)值進(jìn)行判斷 username=request.COOKIES.get("username") if not is_login: # 值為空時(shí),執(zhí)行這里,說明之前沒有登錄過,重定向到登錄頁面 return redirect("/login/") return render(request,"index.html",{"username":username})
三、session
上面的cookie是瀏覽器端保存的,現(xiàn)在的session是基于cookie的,但是保存在服務(wù)器端的技術(shù),服務(wù)器在運(yùn)行時(shí)可以為每一個(gè)訪問的瀏覽器設(shè)置一個(gè)session,然后保存在Django下的Django_session表中。
語法:
request.session["k1"]="v1" 設(shè)置session值 request.session.get("k1") 取session值 request.session.flush() 清空session值
基于session的登錄頁面和主頁面的訪問
def login(request): if request.method=="GET": return render(request,"login.html") else: user = request.POST.get("user") pwd = request.POST.get("pwd") user_obj=UserInfo.objects.filter(name=user,pwd=pwd).first() if user_obj: request.session["is_login"]=True request.session["username"]=user return redirect("/index/") return HttpResponse("Error!")def index(request): is_login=request.session.get("is_login") username=request.session.get("username")if not is_login: return redirect("/login/") return render(request,"index.html",{"username":username})
四、圖片驗(yàn)證碼的實(shí)現(xiàn)
HTML文件:登錄頁面
Title {% csrf_token %}登錄頁面名字密碼驗(yàn)證碼
views:
產(chǎn)生隨機(jī)圖片驗(yàn)證的視圖函數(shù) import random from PIL import Image,ImageDraw,ImageFont from io import BytesIO def get_random_color(): return random.randint(0,255),random.randint(0,255),random.randint(0,255) def img_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='' for i in range(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 for i in range(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()) for i in range(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() return HttpResponse(data) def login(request): if request.method=='GET': return render(request,'login.html') else: yan=request.POST.get('yan') if yan.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() if obj : request.session['state']=True request.session['user']=user return HttpResponse('200') else: return HttpResponse('100') else: return HttpResponse('300')
關(guān)于cookie與session如何在Django中使用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。