前段時間看了一些關於驗證碼的文章,就是將一串隨機產生的數字或符號,生成一幅圖片,圖片裡加上一些干擾象素(防止OCR),由用戶肉眼識別其中的驗證碼信息,輸入表單提交網站驗證,驗證成功後才能使用某項功能。
有篇文章也簡單的介紹了實現的方法,如下:
代碼一:
(做為現在的主流開發語言)
/*
* 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);
?>
這段程序已經基本上實現了驗證碼的生成和校驗功能,但是文章作者不知道為什麼卻將驗證碼的內容顯示在表單裡了,這樣的話,只是限制了用戶必須輸入驗證碼,對惡意程序卻沒有任何防范作用。可以說是在難為人,而不是防范攻擊。
不過還好根據原作者的思路,我們可以將驗證串保存在session裡,這樣的話,才具有一定的安全性。
代碼如下:
//file:authform.php(做為現在的主流開發語言)
(做為現在的主流開發語言)
/*
*" Filename:authimg.php(做為現在的主流開發語言)
*/
Header("Content-type:image/PNG");
session_start();
$auth_num="";
session_register(auth_num);
$im=imagecreate(63,20);
srand((double)microtime()*1000000);
$auth_num_k=md5(rand(0,9999));
$auth_num=substr($auth_num_k,17,5);
$black=ImageColorAllocate($im,0,0,0);
$white=ImageColorAllocate($im,255,255,255);
$gray=ImageColorAllocate($im,200,200,200);
//ImageFill($im,63,20,$black);//這行不知道為什麼在我公司的服務器上出錯誤,換個空間ok
imagestring($im,5,10,3,$auth_num,$gray);
for($i=0;$i<200;$i++)
{
$randcolor=ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im,rand()%70,rand()%30,$randcolor);
}
ImagePNG($im);
ImageDestroy($im);
?>
(做為現在的主流開發語言)
/*
* Filename:authpage.php(做為現在的主流開發語言)