台灣最大程式設計社群網站
線上人數
535
 
會員總數:245973
討論主題:189551
歡迎您免費加入會員
討論區列表 >> PHP >> (轉載)php 的密碼驗證範例
[]  
[我要回覆]
回應主題 加入我的關注話題 檢舉此篇討論 將提問者加入個人黑名單
(轉載)php 的密碼驗證範例
價值 : 0 QP  點閱數:3703 回應數:0
樓主

Pitt Chen 版主
初級專家
1512 31
2505 505
發送站內信

捐贈 VP 給 Johnny Chen
作者:hutuworm 來源:糊塗饞寺 
??目前,不少網站為了防止用戶利用機器人自動註冊、登錄、灌水,都採用了 
驗證碼技術。所謂驗證碼,就是將一串隨機產生的數字或符號,生成一幅圖片, 
圖片裡加上一些干擾象素(防止OCR),由用戶肉眼識別其中的驗證碼信息,輸 
入表單提交網站驗證,驗證成市嶀~能使用某項弁遄C 

??我們這裡展示了如何編寫PHP程序實現驗證碼弁遄G 

??代碼一: 

CODE  
  <?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 "驗證成央I"; 
               else 
                       echo "驗證失敗!"; 
       } 
   
  //生成新的四位整數驗證碼 
       while(($authnum=rand()%10000)<1000);  
   ?> 
       <form action=authpage.php method=post> 
       <table> 
               請輸入驗證碼:<input type=text name=authinput style="width: 80px"><br> 
               <input type=submit name="驗證" value="提交驗證碼"> 
               <input type=hidden name=authnum value=<? echo $authnum; ?>> 
               <img src=authimg.php?authnum=<? echo $authnum; ?>> 
       </table> 
       </form>
?>
 


代碼二: 

CODE  
<?php
  /* 
   *   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++)   //?#91;入干擾象素 
       { 
               imagesetpixel($im, rand()%70 , rand()%30 , $black); 
       } 

       ImagePNG($im); 
       ImageDestroy($im); 
?>  



本文程序在Apache 2.0.45 + PHP 4.3.1環境下運行通過。 

上文只是對驗證碼弁鄋漱@個簡單實現,並沒有考慮商用安全性問題。如果要增強安全性,將此弁鄑諵J商業應用,則可以通過以下幾個步驟實現: 

1. 啟用Session。 
2. authnum在authimg.php中生成,並計算md5sum,存入session。 
3. authpage.php將authinput計算md5sum後,與session中的authnum(md5sum)對比得出驗證結果。


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

修改後的代碼如下:

CODE  
<?php 
/* 
*   Filename: authimg.php 
*   Author:   hutuworm 
*   Date:     2003-04-28 
*   @Copyleft hutuworm.org 
*/ 
//生成驗證碼圖片 
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);
//將四位整數驗證碼繪入圖片 
imagestring($im, 5, 10, 3, $authnum, $black); 
for($i=0;$i<200;$i++)   //?#91;入干擾象素 

   $randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
   imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); 

ImagePNG($im); 
ImageDestroy($im); 
?> 


會出現一個 圖片要求再輸入一次 四碼的數字 再驗證~

有興趣的朋友可以自己試一下。

搜尋相關Tags的文章: [ php ] , [ 密碼 ] , [ 驗證 ] ,
本篇文章發表於2005-03-06 11:11
目前尚無任何回覆
   

回覆
如要回應,請先登入.