程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP生成圖片驗證碼練習筆記

PHP生成圖片驗證碼練習筆記

編輯:關於PHP編程

php生成圖形驗證碼需要借助於php gd庫與session來實例,這樣由gd庫生成圖片給用戶看,再由用戶輸入驗證提交給服務器與session中存儲值進行驗證,下面我們來看全過程吧。

windows系統GD庫開啟

將php.ini文件找到extension=php_gd2.dll  去掉前面的;就行了

linux系統GD庫開啟

##檢測GD庫是否安裝命令
 php5 -m | grep -i gd
 或者
 php -i | grep -i --color gd
##如未安裝GD庫,則為服務器安裝,方法如下
### 如果是源碼安裝,則加入參數
 --with-gd
### 如果是debian系的linux系統,用apt-get安裝,如下
 apt-get install php5-gd
### 如果是CentOS系的系統,用yum安裝,如下
 yum install php-gd
### 如果是suse系的linux系統,用yast安裝,如下
 yast -i php5_gd

好了,php GD庫己經好了下面我們來看php生成圖形驗證碼圖片實例

首先還是給大家先介紹一下驗證碼的簡單概念吧!

1 、驗證碼介紹

驗證碼是將一串隨機產生的數字或符號以圖片的形式展現在頁面上,由用戶肉眼識別其中的驗證碼信息,在進行提交操作的同時,需將圖片上的字符同時提交,輸入提交驗證成功後才能使用某項功能。如果提交的字符與服務器 session保存的不同,則認為提交信息無效。為了避免自動程序分析解析圖片,通常會在圖片上隨機生成一些干擾素或者將字符進行扭曲,增加自動識別難度。用戶提交後將用戶輸入的驗證碼與會話 sessi on中保存的字符串進行比對, 達到驗證的效果。用戶提交表單的時候,接收表單的頁面檢查服務端產生的 sessi on和客戶端提交的表單值是否一致,不
一致則不讀或寫入數據庫。會話 sessi on允許在服務器上儲存小部分用戶信息;這類信息是臨時性的,當用戶離開網站時會被自動刪除。

2、 PHP實現過程
PHP網頁文件被當作一般HTML網頁文件來處理, 並且在編輯時,可以用編輯 HTML的常規方法來編寫。由於PHP在使用時消耗相當少的系統資源, 並且有著開放的源代碼, 而且是免費的,如今PHP已經被更多的網站應用,下面是 PHP實現驗證碼的過程:


(1)生成隨機數
定義用來顯示在圖片上的數字和字母;

循環隨機抽取四位定義好的字母和數字;
將通過數字得來的字符連起來一共是四位;
保存生成的數字和字母, 把生成好的隨機數放到 sessi on變量中,將來跟用戶提交的內容比較。

 代碼如下 復制代碼 < ? php
$ aut hnum_session = ' ; '
$ st r = a ' bcdef ghij k l mnopqrstuv wxyz 1234567890 '
;
$ l = strlen( $ str) ;
f or( $ i= 1 ; $ i< = 4 ; $ i+ + )
{
$ num= rand( 0 , $ l- 1);
$ aut hnum_session. = $ str[ $ num];$ aut hnum_session. = $ str[ $ num];
}
$ _SESSI ON[ " authnum_ses sion" ] ;
? >


(2) 創建圖片
用圖片創建函數確定所創建的圖片大小。

 代碼如下 復制代碼 < ? php
$ i m = i magecreate( 60 , 20);
? >


(3)設置顏色
使用函數創建背景色;
使用函數創建字體色。

 代碼如下 復制代碼

< ? php
$ b lack = ImageColor A ll ocate( $ i m, 0 , 0, 0);
$ white = ImageColor A ll ocate( $ i m, 255 , 255 ,
255);
$ gray = I mageColor A ll ocate ( $ i m , 200 , 200 ,
200);
i magefill ( $ i m , 68 , 30 , $ gray);
$ li = I mageColor A l loca te ( $ i m , 220 , 220 ,
220);
? >


(4)加入干擾素
在不影響用戶輸入的條件下,加入若干干擾線、
干擾象素。

 代碼如下 復制代碼 < ? php
f or( $ i= 0 ; $ i< 3 ; $ i+ + )
{
i mageline( $ i m , rand ( 0 , 30), rand( 0 , 21), rand( 20 , 40), rand( 0 , 21), $ li );
}
f or( $ i= 0 ; $ i< 90 ; $ i+ + )
{
i magesetp i xe l ( $ i m, rand( )% 70 , rand( )% 30
, $ gray);
}
? >


(5)把字符寫在圖像左上角
使用函數 i magestri ng把字符寫在圖像上。

 代碼如下 復制代碼 < ? php
i magest ring( $ i m, 5 , 12 , 5 , $ au t hnu m _ ses2
sion , $ wh i te);
? >


(6)輸出圖像
開啟 sessi on功能;
使用函數輸出圖像。

 代碼如下 復制代碼

< ? phpH eader( "Content - type : i mage /png" ) ;
sessi on_start ( ) ;
I magePNG( $ i m);
? >

上述驗證碼顯示結果如下

 

在需要調用驗證碼進行驗證的頁面當中, 由用戶填寫驗證碼表單, 系統將表單提交的驗證碼數據與上面的 sessi on變量進行比對,若相等表示驗證正確,可以繼續進行; 不相等則錯誤, 終止用戶正在進行的工作,實現用戶使用驗證碼的驗證功能。

無標題文檔

 代碼如下 復制代碼 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題文檔</title>
<script language="javascript">
 function refresh_code()
 {
  form1.imgcode.src="verifycode.php?a="+Math.random();
 }
</script>
</head>
<body>
<form id="form1" name="form1" method="post" action="checkcode.php">
  <label for="code">驗證碼:</label>
  <input type="text" name="code" id="textfield" />
  <img id="imgcode" src="VerifyCode.php" alt="驗證碼" />
  <a href="javascript:refresh_code()">看不清?換一個</a>
  <input type="submit" name="button" id="button" value="提交" />
</form>
</body>
</html>

 

verifycode.php文件代碼如下

 

 代碼如下 復制代碼

<?php
 /*
  圖片驗證碼 Powered By KASON test http://www.bKjia.c0m   */
  session_start();
  $num=4;//驗證碼個數
  $width=80;//驗證碼寬度
  $height=20;//驗證碼高度
  $code=' ';
  for($i=0;$i<$num;$i++)//生成驗證碼
  {
   switch(rand(0,2))
   {
    case 0:$code[$i]=chr(rand(48,57));break;//數字
    case 1:$code[$i]=chr(rand(65,90));break;//大寫字母
    case 2:$code[$i]=chr(rand(97,122));break;//小寫字母
   }
  }
  $_SESSION["VerifyCode"]=$code;
  $image=imagecreate($width,$height);
  imagecolorallocate($image,255,255,255);
  for($i=0;$i<80;$i++)//生成干擾像素
  {
   $dis_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255));
   imagesetpixel($image,rand(1,$width),rand(1,$height),$dis_color);
  }
  for($i=0;$i<$num;$i++)//打印字符到圖像
  {
   $char_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255));
   imagechar($image,60,($width/$num)*$i,rand(0,5),$code[$i],$char_color);
  }
  header("Content-type:image/png");
  imagepng($image);//輸出圖像到浏覽器
  imagedestroy($image);//釋放資源
?>  

 

checkcode.php文件如下

 代碼如下 復制代碼

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<?php
ini_set('display_errors', 'Off');
session_start();
  if((strtoupper($_POST["code"])) == strtoupper(($_SESSION["VerifyCode"]))){
 print("驗證碼正確,");
  }else{
    print("驗證碼錯誤,");
  }
  echo "提交的驗證碼:".strtoupper($_POST["code"]).",正確的驗證碼:".strtoupper($_SESSION["VerifyCode"]);
?>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved