国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Django自定義插件實現網站登錄驗證碼功能

2019-11-25 16:14:30
字體:
來源:轉載
供稿:網友

前言

網站登錄的時候我們常常會看到隨機的驗證碼需要輸入后臺驗證,如圖:

現在我們來實現在Django中通過自定制插件來實現隨機驗證

check_code.py

基于PIL生成一個帶驗證碼的圖片和驗證碼,生成驗證碼圖片需要Monaco.ttf字體(重要),可按自己要求更改check_code中的字體和字體文件位置

#!/usr/bin/env python# -*- coding:utf-8 -*- import randomfrom PIL import Image, ImageDraw, ImageFont, ImageFilter _letter_cases = "abcdefghjkmnpqrstuvwxy" # 小寫字母,去除可能干擾的i,l,o,z_upper_cases = _letter_cases.upper() # 大寫字母_numbers = ''.join(map(str, range(3, 10))) # 數字init_chars = ''.join((_letter_cases, _upper_cases, _numbers))  def create_validate_code(size=(120, 30),             chars=init_chars,             img_type="GIF",             mode="RGB",             bg_color=(255, 255, 255),             fg_color=(0, 0, 255),             font_size=18,             font_type="Monaco.ttf",             length=4,             draw_lines=True,             n_line=(1, 2),             draw_points=True,             point_chance=2):  """  @todo: 生成驗證碼圖片  @param size: 圖片的大小,格式(寬,高),默認為(120, 30)  @param chars: 允許的字符集合,格式字符串  @param img_type: 圖片保存的格式,默認為GIF,可選的為GIF,JPEG,TIFF,PNG  @param mode: 圖片模式,默認為RGB  @param bg_color: 背景顏色,默認為白色  @param fg_color: 前景色,驗證碼字符顏色,默認為藍色#0000FF  @param font_size: 驗證碼字體大小  @param font_type: 驗證碼字體,默認為 ae_AlArabiya.ttf  @param length: 驗證碼字符個數  @param draw_lines: 是否劃干擾線  @param n_lines: 干擾線的條數范圍,格式元組,默認為(1, 2),只有draw_lines為True時有效  @param draw_points: 是否畫干擾點  @param point_chance: 干擾點出現的概率,大小范圍[0, 100]  @return: [0]: PIL Image實例  @return: [1]: 驗證碼圖片中的字符串  """   width, height = size # 寬高  # 創建圖形  img = Image.new(mode, size, bg_color)  draw = ImageDraw.Draw(img) # 創建畫筆   def get_chars():    """生成給定長度的字符串,返回列表格式"""    return random.sample(chars, length)   def create_lines():    """繪制干擾線"""    line_num = random.randint(*n_line) # 干擾線條數     for i in range(line_num):      # 起始點      begin = (random.randint(0, size[0]), random.randint(0, size[1]))      # 結束點      end = (random.randint(0, size[0]), random.randint(0, size[1]))      draw.line([begin, end], fill=(0, 0, 0))   def create_points():    """繪制干擾點"""    chance = min(100, max(0, int(point_chance))) # 大小限制在[0, 100]     for w in range(width):      for h in range(height):        tmp = random.randint(0, 100)        if tmp > 100 - chance:          draw.point((w, h), fill=(0, 0, 0))   def create_strs():    """繪制驗證碼字符"""    c_chars = get_chars()    strs = ' %s ' % ' '.join(c_chars) # 每個字符前后以空格隔開     font = ImageFont.truetype(font_type, font_size)    font_width, font_height = font.getsize(strs)     draw.text(((width - font_width) / 3, (height - font_height) / 3),         strs, font=font, fill=fg_color)     return ''.join(c_chars)   if draw_lines:    create_lines()  if draw_points:    create_points()  strs = create_strs()   # 圖形扭曲參數  params = [1 - float(random.randint(1, 2)) / 100,       0,       0,       0,       1 - float(random.randint(1, 10)) / 100,       float(random.randint(1, 2)) / 500,       0.001,       float(random.randint(1, 2)) / 500       ]  img = img.transform(size, Image.PERSPECTIVE, params) # 創建扭曲   img = img.filter(ImageFilter.EDGE_ENHANCE_MORE) # 濾鏡,邊界加強(閾值更大)   return img, strs

創建urls和views

views.py:

# 將check_code包放在合適的位置,導入即可,我是放在utils下面from utils import check_code def create_code_img(request):  f = BytesIO() #直接在內存開辟一點空間存放臨時生成的圖片   img, code = check_code.create_validate_code() #調用check_code生成照片和驗證碼  request.session['check_code'] = code #將驗證碼存在服務器的session中,用于校驗  img.save(f,'PNG') #生成的圖片放置于開辟的內存中  return HttpResponse(f.getvalue()) #將內存的數據讀取出來,并以HttpResponse返回

urls我的設置:url(r'^create_code_img/', views.create_code_img) 

前端應用驗證碼和點擊自動刷新

html:

<div class="row">  <div class="col-xs-7">    <input type="text" class="form-control" name="check_code" id="check_code" placeholder="請輸入驗證碼">  </div>  <div class="col-xs-5">   <img id="check_code_img" src="/create_code_img/" onclick="refresh_check_code(this)">{# src是url路徑,可得到驗證碼圖片,點擊時調用refresh_check_code#}  </div><br></div>

javascript:

<script>   function refresh_check_code(ths) {      ths.src += '?';{# src后面加問好會自動刷新驗證碼img的src#}     }</script>

login的Views

login的Views進行數據驗證,然后做相應的處理

post_check_code = request.POST.get('check_code')session_check_code = request.session['check_code']if post_check_code.lower() == session_check_code.lower() :  pass

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南投县| 龙海市| 和田县| 兴业县| 吉安县| 陇南市| 即墨市| 桃园市| 上饶县| 靖安县| 盘山县| 呼和浩特市| 尼勒克县| 忻州市| 敖汉旗| 宝山区| 政和县| 盱眙县| 崇明县| 四川省| 临泉县| 平安县| 江都市| 鹿邑县| 子洲县| 太白县| 凉城县| 莆田市| 荆州市| 油尖旺区| 乌拉特后旗| 田阳县| 惠东县| 牡丹江市| 宁都县| 仁布县| 太和县| 沐川县| 万全县| 体育| 蒙自县|