本文實例講述了django框架登錄加上驗證碼校驗實現驗證功能。分享給大家供大家參考,具體如下:
驗證碼生成函數
1
|
pip install pillow |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
# /verify_code def verif_ycode(request): #引入繪圖模塊 from pil import image, imagedraw, imagefont #引入隨機函數模塊 import random #定義變量,用于畫面的背景色、寬、高 bgcolor = (random.randrange( 20 , 100 ), random.randrange( 20 , 100 ), random.randrange( 20 , 100 )) width = 100 height = 50 #創建畫面對象 im = image.new( 'rgb' , (width, height), bgcolor) #創建畫筆對象 draw = imagedraw.draw(im) #調用畫筆的point()函數繪制噪點 for i in range ( 0 , 100 ): xy = (random.randrange( 0 , width), random.randrange( 0 , height)) fill = (random.randrange( 0 , 255 ), 255 , random.randrange( 0 , 255 )) draw.point(xy, fill = fill) #定義驗證碼的備選值 str = '1234567890qwertyuiopasdfghjklzxcvbnmqwertyuiopasdfghjklzxcvbnm' #隨機選取4個值作為驗證碼 rand_str = '' for i in range ( 0 , 4 ): rand_str + = str [random.randrange( 0 , len ( str ))] #構造字體對象 # font = imagefont.truetype('楷體', 40) #構造字體顏色 fontcolor1 = ( 255 , random.randrange( 0 , 255 ), random.randrange( 0 , 255 )) fontcolor2 = ( 255 , random.randrange( 0 , 255 ), random.randrange( 0 , 255 )) fontcolor3 = ( 255 , random.randrange( 0 , 255 ), random.randrange( 0 , 255 )) fontcolor4 = ( 255 , random.randrange( 0 , 255 ), random.randrange( 0 , 255 )) #繪制4個字 draw.text(( 5 , 2 ), rand_str[ 0 ], fill = fontcolor1) draw.text(( 25 , 2 ), rand_str[ 1 ], fill = fontcolor2) draw.text(( 50 , 2 ), rand_str[ 2 ], fill = fontcolor3) draw.text(( 75 , 2 ), rand_str[ 3 ], fill = fontcolor4) #釋放畫筆 del draw # 存入session,用于做進一步驗證 request.session[ 'verifycode' ] = rand_str #內存文件操作 import io buf = io.bytesio() #將圖片保存在內存中,文件類型為png im.save(buf, 'png' ) #將內存中的圖片數據返回給客戶端,mime類型為圖片png return httpresponse(buf.getvalue(), 'image/png' ) |
login.html
html文件加上<img src="/verify_code" python" id="highlighter_756147">
# 獲取驗證碼
vcode1
=
request.post.get(
'vcode'
)
# 用戶輸入的驗證碼
vcode2
=
request.session.get(
'verifycode'
)
# 獲取session中保存的驗證碼