Django中使用pillow實(shí)現(xiàn)登錄驗(yàn)證碼功能(帶刷新驗(yàn)證碼功能)
首先在項(xiàng)目里建立common目錄,編寫驗(yàn)證碼的函數(shù)
verification_code.py
import random from PIL import Image, ImageFont, ImageDraw def get_code(): mode = 'RGB' bg_width = 180 #這個(gè)是驗(yàn)證碼那個(gè)框框的寬度 bg_height = 30 #這個(gè)是驗(yàn)證碼那個(gè)框框的高度 bg_size = (bg_width, bg_height) bg_color = (255, 255, 255) ttf_path = 'config/DejaVuSansMono.ttf'#這個(gè)是字體,從linux里扒出來餓字體 # ttf_path = '/usr/share/fonts/truetype/dejavu/DejaVuSansMono.ttf' #這個(gè)要換你服務(wù)器里有的字體才行 img = Image.new(mode, bg_size, bg_color) draw = ImageDraw.Draw(img, mode) font = ImageFont.truetype(ttf_path, 20)#這個(gè)俺也沒懂 # generate text letters = get_letters() for index, text in enumerate(letters): x = 35 * index + 10 #這個(gè)好像是調(diào)那個(gè)字符間距的 y = 0 draw.text((x, y), text, get_rdmcolor(), font) # blur the background for i in range(100): #這個(gè)是設(shè)置干擾線的,數(shù)值越大,干擾的越厲害 x = random.randint(0, bg_width) y = random.randint(0, bg_height) fill = get_rdmcolor() draw.point((x, y), fill) return img, letters def get_letters(): #這個(gè)就是從下面這些字母里去隨機(jī)4個(gè)出來 base = '1234567890qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM' result = [] for i in range(4): #這個(gè)是4位,應(yīng)該改更多位,那么上面的參數(shù)還要調(diào)試,不然顯示有問題 result.append(random.choice(base)) return result def get_rdmcolor(): return random.randint(0, 255), random.randint(0, 255), random.randint(0, 255)
模板
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <form method="POST" action="login/"> <p>用戶名:<input type="text" name="user"></p> <p>密碼:<input type="text" name="pwd"></p> <label for="verification_code">驗(yàn)證碼:</label><input type="text" id="verification_code" name="verification_code" placeholder="Please type below code"> <img class="identifyCode" title="點(diǎn)擊重新獲取" onclick="this.setAttribute('src','verification_code?random='+Math.random())" src="{% url 'verification_code' %}" alt="verification code"> <br> <input type="submit" value="登錄"> </form> <script> </script> </body> </html>
onclick="this.setAttribute('src','verification_code?random='+Math.random())"
這個(gè) onclick事件 就是實(shí)現(xiàn)點(diǎn)擊圖片刷新驗(yàn)證碼功能 ,那為啥要加個(gè)隨機(jī)數(shù)呢,這樣就不會(huì)走瀏覽器緩存了
urls.py
from django.urls import path from test_login_app import views urlpatterns = [ path('',views.index), path('verification_code/', views.verification_code, name='verification_code'), path('login/',views.login), path('index/',views.index2), ]
views.py
from io import BytesIO from django.http import HttpResponse from django.shortcuts import render, redirect from common.verification_code import get_code # Create your views here. def index(request): return render(request, 'login.html') def verification_code(request): img, letters = get_code() request.session['verification_code'] = ''.join(letters) fp = BytesIO() img.save(fp, 'png') return HttpResponse(fp.getvalue(), content_type='image/png') def login(request):#我這個(gè)沒跟數(shù)據(jù)庫聯(lián)動(dòng),簡(jiǎn)單模擬的邏輯 if request.method == 'POST': name = request.POST.get('user') password = request.POST.get('pwd') code = request.POST.get('verification_code') if name == 'fuck' and password == 'xxoo' and code == request.session.get('verification_code', ''): return redirect('/index/') return render(request,'login.html') def index2(request): return render(request,'index.html')
成品如圖
到此這篇關(guān)于Django中使用pillow實(shí)現(xiàn)登錄驗(yàn)證碼功能(帶刷新驗(yàn)證碼功能)的文章就介紹到這了,更多相關(guān)Django刷新驗(yàn)證碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- django如何實(shí)現(xiàn)用戶的注冊(cè)、登錄、注銷功能
- django authentication 登錄注冊(cè)的實(shí)現(xiàn)示例
- Django 登錄注冊(cè)的實(shí)現(xiàn)示例
- Python基于Django實(shí)現(xiàn)驗(yàn)證碼登錄功能
- 利用django和mysql實(shí)現(xiàn)一個(gè)簡(jiǎn)單的web登錄頁面
- Django通過自定義認(rèn)證后端實(shí)現(xiàn)多種登錄方式驗(yàn)證
- Django實(shí)現(xiàn)簡(jiǎn)單登錄的示例代碼
- Django實(shí)現(xiàn)前后端登錄
- 給Django Admin添加驗(yàn)證碼和多次登錄嘗試限制的實(shí)現(xiàn)
- 使用Tastypie登錄Django的問題解決
相關(guān)文章
python 解決mysql where in 對(duì)列表(list,,array)問題
這篇文章主要介紹了python 解決mysql where in 對(duì)列表(list,,array)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06在pycharm中為項(xiàng)目導(dǎo)入anacodna環(huán)境的操作方法
這篇文章主要介紹了在pycharm中為項(xiàng)目導(dǎo)入anacodna環(huán)境的操作方法,本文圖文并茂通過實(shí)例詳解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02Python機(jī)器學(xué)習(xí)pytorch模型選擇及欠擬合和過擬合詳解
如何發(fā)現(xiàn)可以泛化的模式是機(jī)器學(xué)習(xí)的根本問題,將模型在訓(xùn)練數(shù)據(jù)上過擬合得比潛在分布中更接近的現(xiàn)象稱為過擬合,用于對(duì)抗過擬合的技術(shù)稱為正則化2021-10-10python 實(shí)現(xiàn)在txt指定行追加文本的方法
下面小編就為大家分享一篇python 實(shí)現(xiàn)在txt指定行追加文本的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-04-04