用PHP實(shí)現(xiàn)驗(yàn)證碼功能
作者:hutuworm 來(lái)源:糊涂饞寺
目前,不少網(wǎng)站為了防止用戶利用機(jī)器人自動(dòng)注冊(cè)、登錄、灌水,都采用了
驗(yàn)證碼技術(shù)。所謂驗(yàn)證碼,就是將一串隨機(jī)產(chǎn)生的數(shù)字或符號(hào),生成一幅圖片,
圖片里加上一些干擾象素(防止OCR),由用戶肉眼識(shí)別其中的驗(yàn)證碼信息,輸
入表單提交網(wǎng)站驗(yàn)證,驗(yàn)證成功后才能使用某項(xiàng)功能。
我們這里展示了如何編寫(xiě)PHP程序?qū)崿F(xiàn)驗(yàn)證碼功能:
代碼一:
<?php
/*
* Filename: authpage.php
* Author: hutuworm
* Date: 2003-04-28
* @Copyleft hutuworm.org
*/
srand((double)microtime()*1000000);
//驗(yàn)證用戶輸入是否和驗(yàn)證碼一致
if(isset($HTTP_POST_VARS['authinput']))
{
if(strcmp($HTTP_POST_VARS['authnum'],$HTTP_POST_VARS['authinput'])==0)
echo "驗(yàn)證成功!";
else
echo "驗(yàn)證失敗!";
}
//生成新的四位整數(shù)驗(yàn)證碼
while(($authnum=rand()%10000)<1000);
?>
<form action=authpage.php method=post>
<table>
請(qǐng)輸入驗(yàn)證碼:<input type=text name=authinput style="width: 80px"><br>
<input type=submit name="驗(yàn)證" value="提交驗(yàn)證碼">
<input type=hidden name=authnum value=<? echo $authnum; ?>>
<img src=authimg.php?authnum=<? echo $authnum; ?>>
</table>
</form>
代碼二:
<?php
/*
* Filename: authimg.php
* Author: hutuworm
* Date: 2003-04-28
* @Copyleft hutuworm.org
*/
//生成驗(yàn)證碼圖片
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);
//將四位整數(shù)驗(yàn)證碼繪入圖片
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環(huán)境下運(yùn)行通過(guò)。
上文只是對(duì)驗(yàn)證碼功能的一個(gè)簡(jiǎn)單實(shí)現(xiàn),并沒(méi)有考慮商用安全性問(wèn)題。如果要增強(qiáng)安全性,將此功能投入商業(yè)應(yīng)用,則可以通過(guò)以下幾個(gè)步驟實(shí)現(xiàn):
1. 啟用Session。
2. authnum在authimg.php中生成,并計(jì)算md5sum,存入session。
3. authpage.php將authinput計(jì)算md5sum后,與session中的authnum(md5sum)對(duì)比得出驗(yàn)證結(jié)果。
本站注:作者使用了簡(jiǎn)單的代碼實(shí)現(xiàn)了很酷的功能。不過(guò)在添加干擾像素時(shí)的效果不是太好,大家可以看一下雨聲論壇登錄時(shí)的效驗(yàn)碼(http://ror.cn/perl/ut/user_login.cgi),偶把第二段代碼稍改了一下,生成了與其類(lèi)似的效果。
修改后的代碼如下:
<?php
/*
* Filename: authimg.php
* Author: hutuworm
* Date: 2003-04-28
* @Copyleft hutuworm.org
*/
//生成驗(yàn)證碼圖片
Header("Content-type: image/PNG");
srand((double)microtime()*1000000);
$im = imagecreate(62,20);
$black = ImageColorAllocate($im, 0,0,0);
$white = ImageColorAllocate($im, 255,255,255);
$gray = ImageColorAllocate($im, 200,200,200);
imagefill($im,68,30,$gray);
while(($authnum=rand()%100000)<10000);
//將四位整數(shù)驗(yàn)證碼繪入圖片
imagestring($im, 5, 10, 3, $authnum, $black);
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);
?>
相關(guān)文章
PHP中在數(shù)據(jù)庫(kù)中保存Checkbox數(shù)據(jù)(2)
PHP中在數(shù)據(jù)庫(kù)中保存Checkbox數(shù)據(jù)(2)...2006-10-10
WINDOWS服務(wù)器安裝多套PHP的另類(lèi)解決方案
WINDOWS服務(wù)器安裝多套PHP的另類(lèi)解決方案...2006-10-10
PHP編碼規(guī)范之注釋和文件結(jié)構(gòu)說(shuō)明
理解學(xué)習(xí)PHP編碼規(guī)范之注釋和文件結(jié)構(gòu),編寫(xiě)規(guī)則的代碼與目錄結(jié)構(gòu)讓大家能快速的熟悉。提高協(xié)同工作效率。2010-07-07
用Zend Encode編寫(xiě)開(kāi)發(fā)PHP程序
用Zend Encode編寫(xiě)開(kāi)發(fā)PHP程序...2006-10-10

