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變量中,將來跟用戶提交的內容比較。
(2) 創建圖片
用圖片創建函數確定所創建的圖片大小。
(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)加入干擾素
在不影響用戶輸入的條件下,加入若干干擾線、
干擾象素。
(5)把字符寫在圖像左上角
使用函數 i magestri ng把字符寫在圖像上。
(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">
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"]);
?>