澳门新葡萄京娱乐场PHP实现验证码

图形数字验证代码Code:?/** Filename:
authpage.php*/srand((double)microtime()*1000000);//验证用户输入是否和验证码一致if(isset($_POST[‘authinput’])){if(strcmp($_POST[‘authnum’],$_POST[‘authinput’])==0)echo
“验证成功!”;elseecho
“验证失败!”;}//生成新的四位整数验证码while(($authnum=rand()%10000)1000);?form
action=authpage.php method=posttable请输入验证码:input type=text
name=authinput brinput type=submit name=”验证” value=”提交验证码”input
type=hidden name=authnum value=? echo $authnum; ?img
src=authimg.php?authnum=? echo $authnum;
?/table/form————————————————————————————————————-?/**
Filename: authimg.php*///生成验证码图片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’], $white);for($i=0;$i50;$i++)
//加入干扰象素{imagesetpixel($im, rand()%70 , rand()%30 ,
$gray);}ImagePNG($im);ImageDestroy($im);?

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

数字验证码

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

 <? 
   /* 
    *   Filename: authpage.php 
    */ 
session_start();
     //   srand((double)microtime()*1000000); 
        $authnum = $_SESSION[”authnum”];
        //验证用户输入是否和验证码一致 
        if(isset($_POST[”authinput”]))  
        { 
                if(strcmp($_POST[”authinput”],$_SESSION[”authnum”])==0) 
                        echo “验证成功!”; 
                else 
                        echo “验证失败!”; 
        } 
    
        //生成新的四位整数验证码 

代码一:

    //    while(($authnum=rand()%10000)<1000);  
    ?> 
        <form action=test4.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> 

?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.php
method=post table 请输入验证码:input type=text name=authinput br input
type=submit name=”验证” value=”提交验证码” input type=hidden
name=authnum value=? echo $authnum; ? img src=authimg.php?authnum=? echo
$authnum; ? /table /form

 authimg.php

代码二: ?php /* * Filename: authimg.php * Author: hutuworm * Date:
2003-04-28 * @Copyleft hutuworm.org */

<?php 
//生成验证码图片 
Header(“Content-type: image/PNG”);  
srand((double)microtime()*1000000);//播下一个生成随机数字的种子,以方便下面随机数生成的使用

//生成验证码图片 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);

session_start();//将随机数存入session中
$_SESSION[”authnum”]=””;
$im = imagecreate(62,20); //制定图片背景大小

//将四位整数验证码绘入图片 imagestring($im, 5, 10, 8,
$HTTP_GET_VARS[‘authnum’], $black);

$black = ImageColorAllocate($im, 0,0,0); //设定三种颜色
$white = ImageColorAllocate($im, 255,255,255); 
$gray = ImageColorAllocate($im, 200,200,200); 

for($i=0;$i50;$i++) //加入干扰象素 { imagesetpixel($im, rand()%70 ,
rand()%30 , $black); }

imagefill($im,0,0,$gray); //采用区域填充法,设定(0,0)

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

while(($authnum=rand()%100000)<10000);
//将四位整数验证码绘入图片 
$_SESSION[”authnum”]=$authnum;
imagestring($im, 5, 10, 3, $authnum, $black);
// 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 座标处像的左上角为 0, 0)。
//如果 font 是 1,2,3,4 或 5,则使用内置字体

本文程序在Apache 2.0.45 + PHP 4.3.1环境下运行通过。

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); 
?>

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

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

本站注:作者使用了简单的代码实现了很酷的功能。不过在添加干扰像素时的效果不是太好,大家可以看一下雨声论坛登录时的效验码(_login.cgi),偶把第二段代码稍改了一下,生成了与其类似的效果。

修改后的代码如下:

?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;$i200;$i++)
//加入干扰象素 { $randcolor =
ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); } ImagePNG($im);
ImageDestroy($im); ?

发表评论

电子邮件地址不会被公开。 必填项已用*标注