1. 程式人生 > >django-博客系統-登錄驗證碼

django-博客系統-登錄驗證碼

value 校驗 and 數字 number mod pillow show name

                    隨機驗證碼

一:首先需要安裝模塊PIL

pip install PIL    #第一個不行就試試第二個
pip install pillow

二:創建圖片

from PIL import Image,ImageDraw,ImageFont

img=Image.New(mode=‘RGB‘,size=(100,50),color=(0,255,0))
draw=ImageDraw(img,‘png‘)

1,畫點


img = Image.new(mode=‘RGB‘, size=(120, 30), color=(255, 255, 255))
draw = ImageDraw.Draw(img, mode=‘RGB‘)
# 第一個參數:表示坐標
# 第二個參數:表示顏色
draw.point([100, 100], fill="red")
draw.point([300, 300], fill=(255, 255, 255))

2,畫線

img = Image.new(mode=‘RGB‘, size=(120, 30), color=(255, 255, 255))
draw = ImageDraw.Draw(img, mode=‘RGB‘)
# 第一個參數:表示起始坐標和結束坐標
# 第二個參數:表示顏色
draw.line((100,100,100,300), fill=‘red‘)
draw.line((100,100,300,100), fill=(255, 255, 255))

3,畫圓

img = Image.new(mode=‘RGB‘, size=(120, 30), color=(255, 255, 255))
draw = ImageDraw.Draw(img, mode=‘RGB‘)
# 第一個參數:表示起始坐標和結束坐標(圓要畫在其中間)
# 第二個參數:表示開始角度
# 第三個參數:表示結束角度
# 第四個參數:表示顏色
draw.arc((100,100,300,300),0,90,fill="red")

4,插入文本

img = Image.new(mode=‘RGB‘, size=(120, 30), color=(255, 255, 255))
draw = ImageDraw.Draw(img, mode=‘RGB‘)
# 第一個參數:表示起始坐標
# 第二個參數:表示寫入內容
# 第三個參數:表示顏色
draw.text([0,0],‘python‘,"red")

5,插入定制文本

img = Image.new(mode=‘RGB‘, size=(120, 30), color=(255, 255, 255))
draw = ImageDraw.Draw(img, mode=‘RGB‘)
# 第一個參數:表示字體文件路徑
# 第二個參數:表示字體大小
font = ImageFont.truetype("kumo.ttf", 28)
# 第一個參數:表示起始坐標
# 第二個參數:表示寫入內容
# 第三個參數:表示顏色
# 第四個參數:表示顏色
draw.text([0, 0], ‘python‘, "red", font=font)

django實例:在圖片上創建隨即字符

視圖函數中

font=ImageFont.TrueType(‘/static/font路徑/‘,20) #第一從外部引入的字體路徑,第二個時候字體大小
lst=[]
for
i in range(5): word_low=chr(random.randint(65,90)) #創建隨即小寫字符 word_upper=chr(random.randint(91,122)) #創建大寫隨即字符 number_str=str(random.randint(0,9)) #創建隨即數字 random_choice=[word_low,word_upper,number_st]
  draw.text([10+i*20],random_choice,(random.randint(0,255),random.randint(0,255),random.randint(0,255)),font)
  #第一是:字體的位置,第二,是放隨即字符,第三是放隨即顏色,第四是字體的樣式.
  lst.append(random_choice) #取到每次循環的隨即字符,放在列表中
lst="".join(lst)    #變成字符串形式.
f=BytesIO() #放在內存
img.save(f,‘png‘) #把圖片保存在內存
data=f.getvalue()    #從內存中拿到數據

request.session[‘random_choice‘]=lst #把所有的隨即字符保存到session,以便後面校驗

return Httpresponse(data)  #把圖片的信息上傳到html裏面

在html裏面

<p>姓名<input type="text" class="username"></p> <p>密碼<input type="password" class="password"></p> <p>驗證碼<input type="text" style="width: 60px" class="code"> <img src="/get_img/" width="100px" height="50px"> </p> <button class="c3">登錄</button> <a href="/regiest/"> <button>註冊</button> </a> <span class="is_false"></span>

函數實例

import random
  
def check_code(width=120, height=30, char_length=5, font_file=‘kumo.ttf‘, font_size=28):
    code = []
    img = Image.new(mode=‘RGB‘, size=(width, height), color=(255, 255, 255))
    draw = ImageDraw.Draw(img, mode=‘RGB‘)
  
    def rndChar():
        """
        生成隨機字母  
        :return:
        """
        return chr(random.randint(65, 90))
  
    def rndColor():
        """
        生成隨機顏色
        :return:
        """
        return (random.randint(0, 255), random.randint(10, 255), random.randint(64, 255))
  
    # 寫文字
    font = ImageFont.truetype(font_file, font_size)
    for i in range(char_length):
        char = rndChar()
        code.append(char)
        h = random.randint(0, 4)
        draw.text([i * width / char_length, h], char, font=font, fill=rndColor())
  
    # 寫幹擾點
    for i in range(40):
        draw.point([random.randint(0, width), random.randint(0, height)], fill=rndColor())
  
    # 寫幹擾圓圈
    for i in range(40):
        draw.point([random.randint(0, width), random.randint(0, height)], fill=rndColor())
        x = random.randint(0, width)
        y = random.randint(0, height)
        draw.arc((x, y, x + 4, y + 4), 0, 90, fill=rndColor())
  
    # 畫幹擾線
    for i in range(5):
        x1 = random.randint(0, width)
        y1 = random.randint(0, height)
        x2 = random.randint(0, width)
        y2 = random.randint(0, height)
  
        draw.line((x1, y1, x2, y2), fill=rndColor())
  
    img = img.filter(ImageFilter.EDGE_ENHANCE_MORE)
    return img,‘‘.join(code)
  
  
if __name__ == ‘__main__‘:
    # 1. 直接打開
    # img,code = check_code()
    # img.show()
  
    # 2. 寫入文件
    # img,code = check_code()
    # with open(‘code.png‘,‘wb‘) as f:
    #     img.save(f,format=‘png‘)
  
    # 3. 寫入內存(Python3)
    # from io import BytesIO
    # stream = BytesIO()
    # img.save(stream, ‘png‘)
    # stream.getvalue()
  
    # 4. 寫入內存(Python2)
    # import StringIO
    # stream = StringIO.StringIO()
    # img.save(stream, ‘png‘)
    # stream.getvalue()
  
    pass

django-博客系統-登錄驗證碼