Django組件之cookie與session的使用方法
一、引子
http協(xié)議是無(wú)狀態(tài)的,就是它不會(huì)記錄請(qǐng)求和響應(yīng)的任何信息,比如你訪(fǎng)問(wèn)一個(gè)服務(wù)器的一個(gè)網(wǎng)頁(yè)時(shí),先要你登錄一下,然后進(jìn)入網(wǎng)頁(yè),但當(dāng)你要進(jìn)入這個(gè)服務(wù)器的另一個(gè)網(wǎng)頁(yè)時(shí),它照常不會(huì)知道剛才你已經(jīng)登錄過(guò)了,又要讓你登錄一下,就是一個(gè)bug。但是,你說(shuō)你每次上網(wǎng)的時(shí)候,只需要登錄一下就行了,并沒(méi)有我說(shuō)的讓你每次都登錄,這是會(huì)話(huà)路徑技術(shù)幫你記錄了你的登錄信息,現(xiàn)在我們們就來(lái)講講Django的會(huì)話(huà)路徑技術(shù)cookie和session,實(shí)現(xiàn)會(huì)話(huà)追蹤。
二、cookie
cookie是key-value結(jié)構(gòu),類(lèi)似于一個(gè)字典。隨著服務(wù)器的響應(yīng)發(fā)送給客戶(hù)端瀏覽器,然后客戶(hù)端瀏覽器會(huì)把cookie保存起來(lái),當(dāng)下一次再訪(fǎng)問(wèn)服務(wù)器時(shí)把cookie再發(fā)送給服務(wù)器。

語(yǔ)法:
response.set_cookie() #這是設(shè)置cookie值 request.COOKIES #取cookie值
基于cookie的登錄頁(yè)面和主頁(yè)面
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: 用戶(hù)驗(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)入主頁(yè)面視圖
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í)行這里,說(shuō)明之前沒(méi)有登錄過(guò),重定向到登錄頁(yè)面
return redirect("/login/")
return render(request,"index.html",{"username":username})
三、session
上面的cookie是瀏覽器端保存的,現(xiàn)在的session是基于cookie的,但是保存在服務(wù)器端的技術(shù),服務(wù)器在運(yùn)行時(shí)可以為每一個(gè)訪(fǎng)問(wèn)的瀏覽器設(shè)置一個(gè)session,然后保存在Django下的Django_session表中。

語(yǔ)法:
request.session["k1"]="v1" 設(shè)置session值
request.session.get("k1") 取session值
request.session.flush() 清空session值
基于session的登錄頁(yè)面和主頁(yè)面的訪(fǎng)問(wèn)
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文件:登錄頁(yè)面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="/static/css/bootstrap.css" rel="external nofollow" >
<script src="/static/jquery-3.3.1.js"></script>
<script src="/static/js/bootstrap.js"></script>
</head>
<body>
{% csrf_token %}
<div class="container">
<div class="row">
<div class="col-md-5">
<div style="color: blue;font-size: 20px">登錄頁(yè)面</div>
<div class="form-group">
名字 <input type="text" name="user" class="form-control">
</div>
<div class="form-group">
密碼 <input type="password" name="pwd" class="form-control">
</div>
<div class="row form-group">
<div class="col-md-6">驗(yàn)證碼<input type="text" name="yan" class="form-control"></div>
<div class="col-md-6" style="line-height:60px"><img src="/img_drow/" alt="" width="200" height="40"></div>
</div>
<button class="login">登錄</button>
<p style="color: red;font-size: 30px"></p>
</div>
</div>
</div>
<script>
$('.login').click(function () {
var name = $('[name="user"]').val();
var pw = $('[name="pwd"]').val();
var yan = $('[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/'
}
else if (data == '100') {
$('p').html('用戶(hù)名或密碼輸入錯(cuò)誤')
}
else {
$('p').html('驗(yàn)證碼錯(cuò)誤');
var num=Math.random();
$('img').attr('src', '/img_drow?'+num)
}
}
})
});
$('img').click(function () {
var num=Math.random();
$(this).attr('src', '/img_drow?'+num)
})
</script>
</body>
</html>
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')
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
django多對(duì)多表的創(chuàng)建,級(jí)聯(lián)刪除及手動(dòng)創(chuàng)建第三張表
這篇文章主要介紹了django多對(duì)多表的創(chuàng)建,級(jí)聯(lián)刪除及手動(dòng)創(chuàng)建第三張表,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
Python對(duì)數(shù)據(jù)庫(kù)操作
本文給大家介紹Windows、Linux下安裝MySQL-python,及安裝過(guò)程中常遇到的問(wèn)題,該如何解決,非常具有參考借鑒價(jià)值,特此分享供大家參考2016-03-03
Python利用pynput實(shí)現(xiàn)劃詞復(fù)制功能
這篇文章主要為大家想詳細(xì)介紹了Python如何利用pynput實(shí)現(xiàn)劃詞復(fù)制功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-05-05
Python使用PyMuPDF實(shí)現(xiàn)添加PDF水印
在日常工作中,我們經(jīng)常需要對(duì)PDF文件進(jìn)行處理,其中一項(xiàng)常見(jiàn)的需求是向PDF文件添加水印,本文將介紹如何使用Python編程語(yǔ)言和PyMuPDF庫(kù)在PDF文件中添加水印,感興趣的可以了解一下2023-08-08
Python利用正則表達(dá)式匹配并截取指定子串及去重的方法
Python pyinotify日志監(jiān)控系統(tǒng)處理日志的方法

