VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 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变量中,将来跟用户提交的内容比较,代码如下:

  1. <?php 
  2. $ aut hnum_session = ' ; ' 
  3. $ st r = a ' bcdef ghij k l mnopqrstuv wxyz 1234567890 ' 
  4. $ l = strlen( $ str) ; 
  5. or( $ i= 1 ; $ i< = 4 ; $ i+ + ) 
  6. $ num= rand( 0 , $ l- 1); 
  7. $ aut hnum_session. = $ str[ $ num];$ aut hnum_session. = $ str[ $ num]; 
  8. }//开源代码phpfensi.com 
  9. $ _SESSI ON[ " authnum_ses sion" ] ; 
  10. ?> 

(2) 创建图片

用图片创建函数确定所创建的图片大小,代码如下:

  1. <?php 
  2. $i m = i magecreate( 60 , 20); 
  3. ?> 

 (3)设置颜色

使用函数创建背景色;使用函数创建字体色,代码如下:

  1. <?php 
  2. $ b lack = ImageColor A ll ocate( $ i m, 0 , 0, 0); 
  3. $ white = ImageColor A ll ocate( $ i m, 255 , 255 , 
  4. 255); 
  5. $ gray = I mageColor A ll ocate ( $ i m , 200 , 200 , 
  6. 200); 
  7. i magefill ( $ i m , 68 , 30 , $ gray); 
  8. $ li = I mageColor A l loca te ( $ i m , 220 , 220 , 
  9. 220); 
  10. ?> 
 

(4)加入干扰素

在不影响用户输入的条件下,加入若干干扰线、干扰象素,代码如下:

  1. <? php 
  2. for( $ i= 0 ; $ i< 3 ; $ i+ + ) 
  3. imageline( $ i m , rand ( 0 , 30), rand( 0 , 21), rand( 20 , 40), rand( 0 , 21), $ li ); 
  4. or( $ i= 0 ; $ i< 90 ; $ i+ + ) 
  5. i magesetp i xe l ( $ i m, rand( )% 70 , rand( )% 30 
  6. , $ gray); 
  7. }//开源代码phpfensi.com 
  8. ?>  

(5)把字符写在图像左上角

使用函数 i magestri ng把字符写在图像上,代码如下:

  1. <?php 
  2. imagest ring( $ i m, 5 , 12 , 5 , $ au t hnu m _ ses2 
  3. sion,$ wh i te); 
  4. ?> 

(6)输出图像

开启 sessi on功能;使用函数输出图像,代码如下:

  1. <?php Header( "Content - type : i mage /png" ) ; 
  2. sessi on_start ( ) ; 
  3. I magePNG( $ i m); 
  4. ?> 
 

在需要调用验证码进行验证的页面当中,由用户填写验证码表单,系统将表单提交的验证码数据与上面的 sessi on变量进行比对,若相等表示验证正确,可以继续进行;不相等则错误, 终止用户正在进行的工作,实现用户使用验证码的验证功能,例如下:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
  2. <html xmlns="http://www.w3.org/1999/xhtml"
  3. <head> 
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  5. <title>无标题文档</title> 
  6. <script language="javascript"
  7.  function refresh_code() 
  8.  { 
  9.   form1.imgcode.src="verifycode.php?a="+Math.random(); 
  10.  } 
  11. </script> 
  12. </head> 
  13. <body> 
  14. <form id="form1" name="form1" method="post" action="checkcode.php"
  15.   <label for="code">验证码:</label> 
  16.   <input type="text" name="code" id="textfield" /> 
  17.   <img id="imgcode" src="VerifyCode.php" alt="验证码" /> 
  18.   <a href="javascript:refresh_code()">看不清?换一个</a> 
  19.   <input type="submit" name="button" id="button" value="提交" /> 
  20. </form> 
  21. </body> 
  22. </html> 

verifycode.php文件代码如下:

  1. <?php 
  2.  /* 
  3.   图片验证码 Powered By KASON test http://www.phpfensi.com   */ 
  4.   session_start(); 
  5.   $num=4;//验证码个数 
  6.   $width=80;//验证码宽度 
  7.   $height=20;//验证码高度 
  8.   $code=' '
  9.   for($i=0;$i<$num;$i++)//生成验证码 
  10.   { 
  11.    switch(rand(0,2)) 
  12.    { 
  13.     case 0:$code[$i]=chr(rand(48,57));break;//数字 
  14.     case 1:$code[$i]=chr(rand(65,90));break;//大写字母 
  15.     case 2:$code[$i]=chr(rand(97,122));break;//小写字母 
  16.    } 
  17.   } 
  18.   $_SESSION["VerifyCode"]=$code
  19.   $image=imagecreate($width,$height); 
  20.   imagecolorallocate($image,255,255,255); 
  21.   for($i=0;$i<80;$i++)//生成干扰像素 
  22.   { 
  23.    $dis_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255)); 
  24.    imagesetpixel($image,rand(1,$width),rand(1,$height),$dis_color); 
  25.   } 
  26.   for($i=0;$i<$num;$i++)//打印字符到图像 
  27.   { 
  28.    $char_color=imagecolorallocate($image,rand(0,2555),rand(0,255),rand(0,255)); 
  29.    imagechar($image,60,($width/$num)*$i,rand(0,5),$code[$i],$char_color); 
  30.   } 
  31.   header("Content-type:image/png"); 
  32.   imagepng($image);//输出图像到浏览器 
  33.   imagedestroy($image);//释放资源 
  34. ?> 

checkcode.php文件如下,代码如下:

  1. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  2. <?php 
  3. ini_set('display_errors''Off'); 
  4. session_start(); 
  5.   if((strtoupper($_POST["code"])) == strtoupper(($_SESSION["VerifyCode"]))){ 
  6.  print("验证码正确,"); 
  7.   }else
  8.     print("验证码错误,"); 
  9.   } 
  10.   echo "提交的验证码:".strtoupper($_POST["code"]).",正确的验证码:".strtoupper($_SESSION["VerifyCode"]); 
  11. ?> 
  12.  

出处:http://www.phpfensi.com/php/20140818/4408.html


相关教程