驗證碼通常是用來安全保證我們網站注冊或登錄不被注入的,但為了更安全我們通常會生成一些混合驗證碼了,下面一起來看看例子.
在我們開發登錄模塊或者是論壇的灌水模塊的時候,為了防止惡意提交,需要用到驗證碼,驗證碼就是用來區分人和機器的一種手段,當然這種手段不是萬無一失,但總歸會起到一些作用.
驗證碼的實現需要GD庫的支持,沒有開啟GD庫的童鞋需開啟GD庫,其實驗證碼的制作和使用非常的簡單,僅僅只是需要4個步驟就可以搞定:創建驗證碼底圖,顯示驗證碼內容,增加干擾元素,輸出驗證碼,下面我們來進行步驟拆分:
第一步:創建驗證碼底圖
$image = imagecreatetruecolor(100, 30); // 創建一個寬為 100 高為 30 的底圖 該底圖的背景色 為黑色 是系統定義的 $bgcolor = imagecolorallocate($image, 255, 255, 255); // 為上面創建的底圖分配 白色的背景顏色 imagefill($image, 0, 0, $bgcolor); // 填充白色背景色
第二步:顯示驗證碼內容
// 輸出驗證碼內容 for ($i=0; $i < 4; $i++) { $fontsize = 6; $fontcolor = imagecolorallocate($image, rand(0,120), rand(0,120), rand(0,120)); $data = 'qwertyuipkjhgfdsazxcvbnm23456789'; $content = substr($data, rand(0, strlen($data)), 1); $x = ($i*100/4) + rand(5,9); $y = rand(5,10); imagestring($image, $fontsize, $x, $y, $content, $fontcolor); //在圖像上水平輸出一行字符串 }
第三步:增加干擾元素
// 增加干擾點元素 for ($i=0; $i < 300; $i++) { $pointcolor = imagecolorallocate($image, rand(50,200), rand(50,200), rand(50,200)); imagesetpixel($image, rand(0,99), rand(0,29), $pointcolor); } //開源軟件:phpfensi.com // 增加干擾線元素 線 和 點 的顏色一定要控制好 要比驗證碼數字的顏色淺 避免出現驗證碼數字看不見的現象 for ($i=0; $i < 4; $i++) { $linecolor = imagecolorallocate($image, rand(100,240), rand(100,240), rand(100,240)); imageline($image, rand(0,99), rand(0,29), rand(0,99), rand(0,29), $linecolor); }
第四步:輸出驗證碼
// 輸出創建的圖像 在輸出圖像之前 必須輸出頭信息 用來規定輸出的圖像類型 header("Content-Type: image/png"); imagepng($image); // 銷毀圖像 imagedestroy($image);
至此,一個簡單的驗證碼就實現了,關於實現驗證碼的注意事項已經寫在了注釋裡,使用驗證碼的時候,我們一般都需要用session來保存以便驗證,在這裡就不作詳細介紹。
以上就是php驗證碼生成代碼,在重要的代碼裡已經進行了注釋,大家可以仔細研究注釋內容,也很重要,希望大家能夠有所收獲吧