在PHP開發過程中實現驗證碼一法_PHP教程

來源:互聯網
上載者:User
  前段時間看了一些關於驗證碼的文章,就是將一串隨機產生的數字或符號,產生一幅圖片,圖片裡加上一些幹擾象素(防止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(做為現在的主流開發語言)

http://www.bkjia.com/PHPjc/508612.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/508612.htmlTechArticle前段時間看了一些關於驗證碼的文章,就是將一串隨機產生的數字或符號,產生一幅圖片,圖片裡加上一些幹擾象素(防止OCR),由使用者肉...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.