PHP语言实现验证码

  为了防止网站中的机器人自动注册以及灌水等

  我们站长朋友都会通过选择利用验证码来解决这类问题;

 然而如何实现用PHP语言生成验证码呢?       

  下面,我们知码网为您提供几段不同的表现方式! 

 

  代码一: 

    <?php 
   /* 
    *   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.phpmethod=post> 
        <table> 
               请输入验证码:<input type=text name=authinputstyle="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>

  代码二: 
 
<?php
   /* 
    *   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)对比得出验证结果。



修改后的代码如下:

<?php 
/* 
 *   Filename: authimg.php 
 *   Author:   hutuworm 
 *   Date:     2003-04-28 
 *   @Copyleft hutuworm.org 
 */ 
//生成验证码图片 
Header("Content-type: image/PNG");  
srand((double)microtime()*1000000); 
$im = imagecreate(62,20); 
$black = ImageColorAllocate($im, 0,0,0); 
$white = ImageColorAllocate($im, 255,255,255); 
$gray = ImageColorAllocate($im, 200,200,200); 
imagefill($im,68,30,$gray); 
while(($authnum=rand()%100000)<10000);
//将四位整数验证码绘入图片 
imagestring($im, 5, 10, 3, $authnum, $black); 
for($i=0;$i<200;$i++)   //加入干扰象素 

    $randcolor =ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
    imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); 

ImagePNG($im); 
ImageDestroy($im); 
?>

以上代码可以轻松实现PHP验证码生存

对于PHP验证码商用,大家可以参考文章中提供的内容

关于验证码识别,知码网可为大家提供大量的相关技术支持

验证码识别、答题等服务,知码网!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值