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

首頁 > 開發 > PHP > 正文

php制作的簡單驗證碼識別代碼

2024-05-04 23:42:35
字體:
來源:轉載
供稿:網友
近期研究一些突破驗證碼方面的知識,記錄下來。一方面算是對這幾天學習知識的總結幫助自己理解;另一方面希望對研究這方面的技術同學有所幫助;另外也希望引起網站管理者的注意,在提供驗證碼時多些考慮進去。由于剛剛接觸這方面的知識,理解比較淺顯,有錯誤再所難免
 

一直想寫這個,過了很久今天興趣來了索性記錄下。

驗證碼

全自動區分計算機和人類的公開圖靈測試(英語:Completely Automated Public Turing test to tell Computers and Humans Apart,簡稱CAPTCHA),俗稱驗證碼,是一種區分用戶是計算機和人的公共全自動程序。在CAPTCHA測試中,作為服務器的計算機會自動生成一個問題由用戶來解答。這個問題可以由計算機生成并評判,但是必須只有人類才能解答。由于計算機無法解答CAPTCHA的問題,所以回答出問題的用戶就可以被認為是人類。
百科介紹

說的簡單點就是隨機生成的字符,輸出在一張圖片上[這里不考慮其他形式的拖拽/短信驗證碼等等]。

常見類型

php制作的簡單驗證碼識別代碼

思路

本文只做演示使用,故取第一張圖片驗證碼作為講解示例。

php制作的簡單驗證碼識別代碼

圖片上的每一點都有其RGB值,通過取色器可以獲取到,肉眼觀察可以看出該圖驗證碼是純數字純色背景

php制作的簡單驗證碼識別代碼

通過取色器看出該驗證碼背景色RGB值為(212,214,204)

實現

下面我們來用PHP的imagecolorsforindex函數取得圖片所有點的RGB值:

$url = 'http://210.32.33.91:8080/reader/captcha.php';$im = imagecreatefromgif($url);imagegif($im, '1.gif');$rgbArray = array();$res = $im;$size = getimagesize($url);$wid = $size['0'];$hid = $size['1'];for ($i = 0; $i < $hid; ++ $i) { for ($j = 0; $j < $wid; ++ $j) {  $rgb = imagecolorat($res, $j, $i);  $rgbArray[$i][$j] = imagecolorsforindex($res, $rgb); }}

結果如下:

php制作的簡單驗證碼識別代碼

各位可能想問這有什么用呢? 下面我們換一種方式來顯示數據,為背景色輸出,驗證碼區域輸出,再來看下:

for ($i = 0; $i < $hid; $i ++) { for ($j = 0; $j < $wid; $j ++) {    if ($rgbArray[$i][$j]['red'] == 212) {   echo '□';  } else {   echo '■';  } } echo "<br>";}

效果:

php制作的簡單驗證碼識別代碼

這樣一下是不是很清楚了。

但是你可能還是有疑問,盡管可以看出來了,但是如何知道是多少呢?

下面我們來分析下:

php制作的簡單驗證碼識別代碼

每個驗證碼直接間距4格,左右間距6/10格,上下間距16/10格。

我們再來去掉這些干擾點,可以看得更清晰些:


php制作的簡單驗證碼識別代碼

是不是很清晰了?可能還是有人會問,你講這么多到底要怎么才能知道圖片上的數字是多少.

好吧,說下我的思路,我們將剛剛的換為0和1,而這些數字形狀是固定的,這樣就可以得到0-9每一個字的每一個區域8*10都有0和1組成了,

php制作的簡單驗證碼識別代碼

我們再來進行每8個切分,去掉4格間距,循環得出0-9的01組合值:

php制作的簡單驗證碼識別代碼

$dic = array( '00011000001111000110011011000011110000111100001111000011011001100011110000011000' => 0, '00011000001110000111100000011000000110000001100000011000000110000001100001111110' => 1, '00111100011001101100001100000011000001100000110000011000001100000110000011111111' => 2, '01111100110001100000001100000110000111000000011000000011000000111100011001111100' => 3, '00000110000011100001111000110110011001101100011011111111000001100000011000000110' => 4, '11111110110000001100000011011100111001100000001100000011110000110110011000111100' => 5, '00111100011001101100001011000000110111001110011011000011110000110110011000111100' => 6, '11111111000000110000001100000110000011000001100000110000011000001100000011000000' => 7, '00111100011001101100001101100110001111000110011011000011110000110110011000111100' => 8, '00111100011001101100001111000011011001110011101100000011010000110110011000111100' => 9);

得出這10個后組合成數組,每次解析圖片RGB換成對應數組值就得到驗證碼值了。下面來演示下:

php制作的簡單驗證碼識別代碼

最后為了準確性,取100個循環看看:

php制作的簡單驗證碼識別代碼

哈哈,準確率100%

寫在最后

本文的目的是為了讓WEB開發者在生成驗證碼時注意安全,請勿用于非法目的.

代碼已在github:



注:相關教程知識閱讀請移步到PHP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永康市| 勐海县| 清远市| 土默特右旗| 雅安市| 长海县| 弥渡县| 宣汉县| 和林格尔县| 开封市| 泸溪县| 南岸区| 常宁市| 时尚| 迁西县| 周至县| 甘肃省| 新蔡县| 河间市| 巴塘县| 明溪县| 勐海县| 赫章县| 秦安县| 毕节市| 黔江区| 定安县| 金堂县| 景洪市| 台江县| 德令哈市| 山东| 成武县| 额济纳旗| 陇西县| 濮阳县| 丰镇市| 微山县| 泰顺县| 永泰县| 乳山市|