本版版主招募中

 
标题: 用PHP实现验证码功能
黄叶
技术专家
Rank: 14Rank: 14Rank: 14Rank: 14



UID 1004
精华 5
积分 57
帖子 93
活跃指数 0
LU金币 5406 个
LU金条 0 个
阅读权限 200
注册 2003-10-26
 
发表于 2003-10-29 16:32  资料  个人空间  短消息  加为好友 
作者:hutuworm 来自:糊涂馋寺

 目前,不少网站为了防止用户利用机器人自动注册、登录、灌水,都采用了
验证码技术。所谓验证码,就是将一串随机产生的数字或符号,生成一幅图片,
图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输
入表单提交网站验证,验证成功后才能使用某项功能。

  我们这里展示了如何编写PHP程序实现验证码功能:
CODE

   <?

  /*

   *   Filename:    authpage.php

   *   Author:   hutuworm

   *   Date:   2003-04-28

   *   @Copyleft    hutuworm.org

   */



       srand((double)microtime()*1000000);



  //验证用户输入是否和验证码一致

       if(isset($HTTP_POST_VARS['authinput']))

       {

               if(strcmp($HTTP_POST_VARS['authnum'],$HTTP_POST_VARS['authinput'])==0)

                       echo "验证成功!";

               else

                       echo "验证失败!";

       }

 

  //生成新的四位整数验证码

       while(($authnum=rand()%10000)<1000);

   ?>

       <form action=authpage.php method=post>

       <table>

               请输入验证码:<input type=text name=authinput style="width: 80px"><br>

               <input type=submit name="验证" value="提交验证码">

               <input type=hidden name=authnum value=<? echo $authnum; ?>>

               <img src=authimg.php?authnum=<? echo $authnum; ?>>

       </table>

       </form>



CODE

 <?

  /*

   *   Filename:    authimg.php

   *   Author:   hutuworm

   *   Date:   2003-04-28

   *   @Copyleft    hutuworm.org

   */



  //生成验证码图片

       Header("Content-type: image/PNG");

       srand((double)microtime()*1000000);

       $im = imagecreate(58,28);

       $black = ImageColorAllocate($im, 0,0,0);

       $white = ImageColorAllocate($im, 255,255,255);

       $gray = ImageColorAllocate($im, 200,200,200);

       imagefill($im,68,30,$gray);



  //将四位整数验证码绘入图片

       imagestring($im, 5, 10, 8, $HTTP_GET_VARS['authnum'], $black);



       for($i=0;$i<50;$i++)   //加入干扰象素

       {

               imagesetpixel($im, rand()%70 , rand()%30 , $black);

       }



       ImagePNG($im);

       ImageDestroy($im);



 本文程序在Apache 2.0.45 + PHP 4.3.1环境下运行通过。
上文只是对验证码功能的一个简单实现,并没有考虑商用安全性问题。如果要增强安全性,将此功能投入商业应用,则可以通过以下几个步骤实现:

1. 启用Session。
2. authnum在authimg.php中生成,并计算md5sum,存入session。
3. authpage.php将authinput计算md5sum后,与session中的authnum(md5sum)对比得出验证结果

顶部
 



当前时区 GMT+8, 现在时间是 2008-11-23 17:48
乐悠LoveUnix论坛-京ICP备05005823号

Thanks to Discuz!  © 2001-2007    Power by LoveUnix.net
Processed in 0.051002 second(s), 6 queries , Gzip enabled

清除 Cookies - 联系我们 - 乐悠LoveUnix - Archiver