摘要:文章鏈接日常在網(wǎng)站使用過程中經(jīng)常遇到圖形驗證,今天準(zhǔn)備自己做個圖形驗證碼,這算是個簡單的功能,也適合新手練習(xí)的,便于自己學(xué)習(xí)。生成隨機(jī)顏色,返回的是三色。隨機(jī)畫線,在圖片寬高范圍內(nèi)隨機(jī)生成個坐標(biāo)點,并通過隨機(jī)顏色產(chǎn)生線條。
文章鏈接:https://mp.weixin.qq.com/s/LYUBRNallHcjnhJb1R3ZBg
日常在網(wǎng)站使用過程中經(jīng)常遇到圖形驗證,今天準(zhǔn)備自己做個圖形驗證碼,這算是個簡單的功能,也適合新手練習(xí)的,便于自己學(xué)習(xí)。
主要用到的庫--PIL圖像處理庫,簡單的思路,我們需要隨機(jī)的顏色,隨機(jī)的數(shù)字或字母,隨機(jī)的線條、點作為干擾元素 拼湊成一張圖片。
生成隨機(jī)顏色,返回的是rgb三色。
def getRandomColor(): r = random.randint(0, 255) g = random.randint(0, 255) b = random.randint(0, 255) return (r, g, b)
從數(shù)字、大小寫字母里生成隨機(jī)字符。
def getRandomChar(): random_num = str(random.randint(0, 9)) random_lower = chr(random.randint(97, 122)) # 小寫字母a~z random_upper = chr(random.randint(65, 90)) # 大寫字母A~Z random_char = random.choice([random_num, random_lower, random_upper]) return random_char
圖片操作,生成一張隨機(jī)背景色的圖片,隨機(jī)生成5種字符+5種顏色,在圖片上描繪字,由于默認(rèn)的字體很小,還需要對字進(jìn)行處理,不同系統(tǒng)下的字體文件存放位置不一樣,這里我是把window下的 arial.ttf 字體復(fù)制到了當(dāng)前文件夾下直接使用的。
# 圖片寬高 width = 160 height = 50 def createImg(): bg_color = getRandomColor() # 創(chuàng)建一張隨機(jī)背景色的圖片 img = Image.new(mode="RGB", size=(width, height), color=bg_color) # 獲取圖片畫筆,用于描繪字 draw = ImageDraw.Draw(img) # 修改字體 font = ImageFont.truetype(font="arial.ttf", size=36) for i in range(5): # 隨機(jī)生成5種字符+5種顏色 random_txt = getRandomChar() txt_color = getRandomColor() # 避免文字顏色和背景色一致重合 while txt_color == bg_color: txt_color = getRandomColor() # 根據(jù)坐標(biāo)填充文字 draw.text((10 + 30 * i, 3), text=random_txt, fill=txt_color, font=font) # 打開圖片操作,并保存在當(dāng)前文件夾下 with open("test.png", "wb") as f: img.save(f, format="png")
這個時候可以看到文件夾下面的圖片
這里是張很清晰的圖片,為了有干擾元素,這里還需要在圖片加入些線條、點作為干擾點。
隨機(jī)畫線,在圖片寬高范圍內(nèi)隨機(jī)生成2個坐標(biāo)點,并通過隨機(jī)顏色產(chǎn)生線條。
def drawLine(draw): for i in range(5): x1 = random.randint(0, width) x2 = random.randint(0, width) y1 = random.randint(0, height) y2 = random.randint(0, height) draw.line((x1, y1, x2, y2), fill=getRandomColor())
隨機(jī)畫點,隨機(jī)生成橫縱坐標(biāo)點。
def drawPoint(draw): for i in range(50): x = random.randint(0, width) y = random.randint(0, height) draw.point((x,y), fill=getRandomColor())
生成方法
def createImg(): bg_color = getRandomColor() # 創(chuàng)建一張隨機(jī)背景色的圖片 img = Image.new(mode="RGB", size=(width, height), color=bg_color) # 獲取圖片畫筆,用于描繪字 draw = ImageDraw.Draw(img) # 修改字體 font = ImageFont.truetype(font="arial.ttf", size=36) for i in range(5): # 隨機(jī)生成5種字符+5種顏色 random_txt = getRandomChar() txt_color = getRandomColor() # 避免文字顏色和背景色一致重合 while txt_color == bg_color: txt_color = getRandomColor() # 根據(jù)坐標(biāo)填充文字 draw.text((10 + 30 * i, 3), text=random_txt, fill=txt_color, font=font) # 畫干擾線點 drawLine(draw) drawPoint(draw) # 打開圖片操作,并保存在當(dāng)前文件夾下 with open("test.png", "wb") as f: img.save(f, format="png")
最終生成的圖片
這里介紹的是圖片生成的方法,可以將圖片直接顯示在前端,也可以使用接口返回url。這里我簡單的把圖片做成鏈接顯示在網(wǎng)頁上,https://www.manjiexiang.cn/blog/validate 用Django做的,需要注意的是圖片保存的路徑。
歡迎關(guān)注我的個人博客:https://www.manjiexiang.cn/
更多精彩歡迎關(guān)注微信號:春風(fēng)十里不如認(rèn)識你
一起學(xué)習(xí),一起進(jìn)步,歡迎上車,有問題隨時聯(lián)系,一起解決?。?!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/44959.html
摘要:現(xiàn)在的網(wǎng)頁中,為了防止機(jī)器人提交表單,圖片驗證碼是很常見的應(yīng)對手段之一?,F(xiàn)在就給出用的庫實現(xiàn)驗證碼圖片的代碼。代碼中有詳細(xì)注釋。生成的驗證碼圖片效果這時候,細(xì)心的同學(xué)可能要問,如果每次生成驗證碼,都要先保存生成的圖片,再顯示到頁面。 現(xiàn)在的網(wǎng)頁中,為了防止機(jī)器人提交表單,圖片驗證碼是很常見的應(yīng)對手段之一。這里就不詳細(xì)介紹了,相信大家都遇到過。 現(xiàn)在就給出用Python的PIL庫實現(xiàn)驗證...
摘要:在這兩種情況下,如果你簽名的都是用戶,那么該用戶可以在激活賬戶和升級賬戶時,復(fù)用的可變部分。變量是一個元組,包括一個透視變換的系數(shù)。 額,一個突然的交流讓我想起來我耽擱許久各種驗證的實現(xiàn)遲遲沒做過趁著這個機(jī)會就搞了一下分為三部分:郵箱驗證,短信驗證,圖片驗證碼 郵箱驗證 這個部分是主要參考的經(jīng)典書籍-狗書思路就是根據(jù)用戶某些信息通過JSON Web簽名生成token,然后再發(fā)送郵件驗證...
摘要:運行結(jié)果如果運行結(jié)果一致則證明安裝成功。上一篇文章網(wǎng)絡(luò)爬蟲實戰(zhàn)請求庫安裝下一篇文章網(wǎng)絡(luò)爬蟲實戰(zhàn)數(shù)據(jù)庫的安裝 上一篇文章:Python3網(wǎng)絡(luò)爬蟲實戰(zhàn)---2、請求庫安裝:GeckoDriver、PhantomJS、Aiohttp下一篇文章:Python3網(wǎng)絡(luò)爬蟲實戰(zhàn)---數(shù)據(jù)庫的安裝:MySQL、MongoDB、Redis 抓取下網(wǎng)頁代碼之后,下一步就是從網(wǎng)頁中提取信息,提取信息的方式有...
摘要:生成驗證碼圖形驗證碼校驗驗證碼生成驗證碼圖形驗證碼校驗驗證碼生成其他類型驗證碼生成圖片驗證碼主要為或者前后端分離設(shè)計。校驗圖片驗證碼。 驗證碼效果 showImg(https://segmentfault.com/img/remote/1460000018639417?w=108&h=40);showImg(https://segmentfault.com/img/remote/146...
摘要:登錄注冊安全風(fēng)險登錄注冊的風(fēng)險點主要有四個暴力破解撞庫遍歷注冊用戶批量注冊。引入了驗證碼機(jī)制同樣引入了額外的安全風(fēng)險,比如短信驗證碼的短信炸彈風(fēng)險圖形驗證碼的可繞過可識別等。 概述 很多技術(shù)研發(fā)不了解安全,也不重視安全,只有在自己的服務(wù)器被黑掉、被掛馬、被脫褲才想起關(guān)注安全,但是這個時候,技術(shù)架構(gòu)已經(jīng)成型、代碼已經(jīng)在線上穩(wěn)定運行,再亡羊補(bǔ)牢,改代碼、改策略,往往成本巨大、確收效很低。所...
閱讀 2897·2021-11-24 09:39
閱讀 2462·2019-08-30 15:53
閱讀 3035·2019-08-30 13:47
閱讀 1309·2019-08-30 12:50
閱讀 1487·2019-08-29 16:31
閱讀 2649·2019-08-29 13:14
閱讀 1566·2019-08-29 10:55
閱讀 800·2019-08-26 13:32