??目前,不少網站為瞭防止用戶利用機器人自動註冊、登錄、灌水,都采用瞭
驗證碼技術。所謂驗證碼,就是將一串隨機產生的數字或符號,生成一幅圖片,
圖片裡加上一些幹擾象素(防止OCR),由用戶肉眼識別其中的驗證碼信息,輸
入表單提交網站驗證,驗證成功後才能使用某項功能。
??我們這裡展示瞭如何編寫PHP程序實現驗證碼功能:
??代碼一:
<?
/*
* Filename: authpage.php
* Author: hutuworm
* Date: 2003-04-28
* @Copyleft hutuworm.org
*/
srand((double)microtime()*1000000);
//驗證用戶輸入是否和驗證碼一致
if(isset($HTTP_POST_VARS[authinput]))
{
if(strcmp($HTTP_POST_VARS[authnum],$HTTP_POST_VARS[authinput])==0)
echo “驗證成功!”;
else
echo “驗證失敗!”;
}
//生成新的四位整數驗證碼
while(($authnum=rand()%10000)<1000);
?>
??代碼二:
??<?
/*
* Filename: authimg.php
* Author: hutuworm
* Date: 2003-04-28
* @Copyleft hutuworm.org
*/
//生成驗證碼圖片
Header(“Content-type: image/PNG”);
srand((double)microtime()*1000000);
$im = imagecreate(58,28);
$black = ImageColorAllocate($im, 0,0,0);
$white = ImageColorAllocate($im, 255,255,255);
$gray = ImageColorAllocate($im, 200,200,200);
imagefill($im,68,30,$gray);
//將四位整數驗證碼繪入圖片
imagestring($im, 5, 10, 8, $HTTP_GET_VARS[authnum], $black);
for($i=0;$i<50;$i++) //加入幹擾象素
{
imagesetpixel($im, rand()%70 , rand()%30 , $black);
}
ImagePNG($im);
ImageDestroy($im);
???>
??本文程序在Apache 2.0.45 + PHP 4.3.1環境下運行通過。