• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    利用PHP實現驗證碼的方法

    發布: 2007-9-07 19:19 | 作者: admin | 來源: eNet論壇 | 查看: 23次 | 進入軟件測試論壇討論

    領測軟件測試網 前段時間看了一些關于驗證碼的文章,就是將一串隨機產生的數字或符號,生成一幅圖片,圖片里加上一些干擾象素(防止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: http://www.enet.com.cnauthimg.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);

      ?>

    這段程序已經基本上實現了驗證碼的生成和校驗功能,但是文章作者不知道為什么卻將驗證碼的內容顯示在表單里了,這樣的話,只是限制了用戶必須輸入驗證碼,對惡意程序卻沒有任何防范作用?梢哉f是在難為人,而不是防范攻擊。

    不過還好根據原作者的思路,我們可以將驗證串保存在session里,這樣的話,才具有一定的安全性。

    代碼如下:

    //file:authform.php







    請輸入驗證碼:















    /*

    * Filename:http://www.enet.com.cnauthimg.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

    */

    session_start();

    $num=trim($num);

    if($auth_num==$num amp;amp; $num<>""){

    echo "驗證成功";

    }else{

    echo "驗證失敗";

    }

    ?>

    寫這篇文章我也是很郁悶的心情,在google用“驗證碼+php”搜索到只有那篇文章,就是找不出個實用點的。沒辦法,雖然外語水平一般,還是忍痛用了全英文搜索,找到了了不知道哪個國家的程序員寫的一段代碼,我把變量換成國人容易看懂的形式,這就是我做的。真的很希望下次用中文也能搜索出點有深度的文章教程,不是說提倡資源共享的么……

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    軟件測試論壇

    軟件測試技術相關文章

    軟件測試技術文章排行榜
    軟件測試技術分類最新內容
    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>