django 利用pillow 進(jìn)行簡單的設(shè)置驗(yàn)證碼功能(python)
1.導(dǎo)入模塊 并定義一個(gè)驗(yàn)證狀態(tài)
from PIL import Image, ImageDraw, ImageFont
from django.utils.six import BytesIO
def verify_code(request):
#引入隨機(jī)函數(shù)模塊
import random
#定義變量,用于畫面的背景色、寬、高
bgcolor = (random.randrange(20, 100), random.randrange(
20, 100), 255)
width = 100
height = 25
#創(chuàng)建畫面對象
im = Image.new('RGB', (width, height), bgcolor)
#創(chuàng)建畫筆對象
draw = ImageDraw.Draw(im)
#調(diào)用畫筆的point()函數(shù)繪制噪點(diǎn)
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)
#定義驗(yàn)證碼的備選值
str1 = 'ABCD123EFGHIJK456LMNOPQRS789TUVWXYZ0'
#隨機(jī)選取4個(gè)值作為驗(yàn)證碼
rand_str = ''
for i in range(0, 4):
rand_str += str1[random.randrange(0, len(str1))]
#構(gòu)造字體對象,ubuntu的字體路徑為“/usr/share/fonts/truetype/freefont”
font = ImageFont.truetype('FreeMono.ttf', 23)
#構(gòu)造字體顏色
fontcolor = (255, random.randrange(0, 255), random.randrange(0, 255))
#繪制4個(gè)字
draw.text((5, 2), rand_str[0], font=font, fill=fontcolor)
draw.text((25, 2), rand_str[1], font=font, fill=fontcolor)
draw.text((50, 2), rand_str[2], font=font, fill=fontcolor)
draw.text((75, 2), rand_str[3], font=font, fill=fontcolor)
#釋放畫筆
del draw
#存入session,用于做進(jìn)一步驗(yàn)證
request.session['verifycode'] = rand_str
#內(nèi)存文件操作
buf = BytesIO()
#將圖片保存在內(nèi)存中,文件類型為png
im.save(buf, 'png')
#將內(nèi)存中的圖片數(shù)據(jù)返回給客戶端,MIME類型為圖片png
return HttpResponse(buf.getvalue(), 'image/png')

3.在網(wǎng)頁中直接放入img中
<img src="/verify_code/" alt="驗(yàn)證碼">

4.使用ajax 獲取驗(yàn)證密碼和賬號(hào)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>login</title>
</head>
<body>
<h1 class="show"></h1>
<input type="text" id = username value="{{username}}"> <br>
<input type="text" id = password> <br>
<input type="text" id = yum> <a>請輸入驗(yàn)證碼</a> <br>
<img src="/verify_code/" alt="驗(yàn)證碼">
<input type="button" id="Ajax" value="ajax登陸"> <br>
<input type="checkbox" id = "ow" name="ow"> 記住密碼<br>
<a href="/get_cookies">點(diǎn)擊到獲取cookies</a>
</body>
<script src="/static/index/js/jquery-3.3.1.min.js"></script>
</html>
<script>
$(function () {
$('#Ajax').click(function () {
username = $('#username').val();
password = $('#password').val();
ow = $("#ow").val();
yum = $('#yum').val();
$.ajax({
'url': '/loginajax',
'type': 'post',
'data': {'username': username, 'password': password,
"yum":yum,},
'success':function(data){
//登陸成功返回1
//登陸失敗返回0
//驗(yàn)證失敗返回3
if (data.res == 1) {
$('.show').show().html('登陸成功')
} else if (data.res == 0) {
$('.show').show().html('登陸失敗')
} else if (data.res == 3){
$('.show').show().html('驗(yàn)證碼輸入失敗')
}
}
});
});
});
</script>
在上面 ajax 中 向服務(wù)器發(fā)送了 賬號(hào)密碼 和 驗(yàn)證碼
在驗(yàn)證函數(shù)中
yzm = request.POST.get('yum') # 獲取傳入的 驗(yàn)證碼
vaue = request.session['verifycode'] # 生成圖片的時(shí)候 把驗(yàn)證碼存到了session 中
if yzm !=vaue: #如果不相等的話會(huì)返回 3 HTML ajax 會(huì)顯示驗(yàn)證錯(cuò)誤
return JsonResponse({'res':3})
成果圖:

總結(jié)
以上所述是小編給大家介紹的django 利用pillow 進(jìn)行簡單的設(shè)置驗(yàn)證碼功能(python),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
如何使用curl命令發(fā)送POST請求(帶token)
這篇文章主要介紹了如何使用curl命令發(fā)送POST請求(帶token),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
Linux如何定時(shí)清空日志內(nèi)容和刪除日志文件
這篇文章主要介紹了Linux如何定時(shí)清空日志內(nèi)容和刪除日志文件,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
詳解如何在Ubuntu 20.04上安裝Xrdp服務(wù)器(遠(yuǎn)程桌面)
這篇文章主要介紹了詳解如何在Ubuntu 20.04上安裝Xrdp服務(wù)器(遠(yuǎn)程桌面),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
Linux中/var/spool/postfix/maildrop占空間很大的原因解析
這篇文章主要給大家介紹了關(guān)于Linux中/var/spool/postfix/maildrop占空間很大的原因解析,文中介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-04-04
在Ubuntu 16.04 Server上安裝Zabbix的方法
這篇文章主要介紹了在Ubuntu 16.04 Server上安裝Zabbix的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03
Linux學(xué)習(xí)之CentOS(二十九)--Linux網(wǎng)卡高級(jí)命令、IP別名及多網(wǎng)卡綁定的方法
本篇文章詳細(xì)的介紹了Linux網(wǎng)卡高級(jí)命令、IP別名及多網(wǎng)卡綁定的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-11-11

