人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當(dāng)前位置:蘿卜系統(tǒng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

用PHP完成驗(yàn)證碼技巧

用PHP完成驗(yàn)證碼技巧

更新時(shí)間:2022-08-08 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

作者:hutuworm 來源:糊涂饞寺
目前,不少網(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)功能。

我們這里展示了如何編寫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)行通過。

上文只是對(duì)驗(yàn)證碼功能的一個(gè)簡單實(shí)現(xiàn),并沒有考慮商用安全性問題。如果要增強(qiáng)安全性,將此功能投入商業(yè)應(yīng)用,則可以通過以下幾個(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é)果。


本站注:作者使用了簡單的代碼實(shí)現(xiàn)了很酷的功能。不過在添加干擾像素時(shí)的效果不是太好,大家可以看一下雨聲論壇登錄時(shí)的效驗(yàn)碼(http://ror.cn/perl/ut/user_login.cgi),偶把第二段代碼稍改了一下,生成了與其類似的效果。

修改后的代碼如下:

<?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);
?>

 

 

溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

本類教程下載

系統(tǒng)下載排行

網(wǎng)站地圖xml | 網(wǎng)站地圖html
主站蜘蛛池模板: 长春市| 施秉县| 特克斯县| 文登市| 襄垣县| 阿合奇县| 宿迁市| 福安市| 日照市| 即墨市| 咸丰县| 桃江县| 武宁县| 潜山县| 高雄市| 临洮县| 宁乡县| 鄂托克旗| 中山市| 福州市| 佛学| 小金县| 兴隆县| 兖州市| 永嘉县| 宁明县| 涿州市| 甘肃省| 黄浦区| 岑巩县| 从化市| 乐业县| 中卫市| 景谷| 康平县| 丹东市| 石景山区| 阜城县| 张家界市| 保德县| 湖北省|