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. ;
  5. $ l = strlen( $ str) ;
  6. f or( $ i= 1 ; $ i< = 4 ; $ i+ + )
  7. {
  8. $ num= rand( 0 , $ l- 1);
  9. $ aut hnum_session. = $ str[ $ num];$ aut hnum_session. = $ str[ $ num];
  10. }//开源代码phpfensi.com
  11. $ _SESSI ON[ " authnum_ses sion" ] ;
  12. ?>

(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. {
  4. imageline( $ i m , rand ( 0 , 30), rand( 0 , 21), rand( 20 , 40), rand( 0 , 21), $ li );
  5. }
  6. f or( $ i= 0 ; $ i< 90 ; $ i+ + )
  7. {
  8. i magesetp i xe l ( $ i m, rand( )% 70 , rand( )% 30
  9. , $ gray);
  10. }//开源代码phpfensi.com
  11. ?>

(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 name="form1" method="post" action="checkcode.php">
  15. <label for="code">验证码:</label>
  16. <input type="text" name="code" />
  17. <img src="VerifyCode.php" alt="验证码" />
  18. <a href="javascript:refresh_code()">看不清?换一个</a>
  19. <input type="submit" name="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. ?>