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儲存的不同,則認為提交資訊無效。為了避免Bot分析解析圖片,通常會在圖片上隨機產生一些幹擾素或者將字元進行扭曲,增加自動識別難度。使用者提交後將使用者輸入的驗證碼與會話 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變數進行比對,若相等表示驗證正確,可以繼續進行; 不相等則錯誤, 終止使用者進行中的工作,實現使用者使用驗證碼的驗證功能。
例
無標題文檔
verifycode.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檔案如下
代碼如下 |
複製代碼 |
ini_set('display_errors', 'Off'); session_start(); if((strtoupper($_POST["code"])) == strtoupper(($_SESSION["VerifyCode"]))){ print("驗證碼正確,"); }else{ print("驗證碼錯誤,"); } echo "提交的驗證碼:".strtoupper($_POST["code"]).",正確的驗證碼:".strtoupper($_SESSION["VerifyCode"]); ?>
|
http://www.bkjia.com/PHPjc/632946.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/632946.htmlTechArticlephp產生圖形驗證碼需要藉助於php gd庫與session來執行個體,這樣由gd庫產生圖片給使用者看,再由使用者輸入驗證提交給伺服器與session中儲存值進行驗...