//验证用户输入是否和验证码一致
if(isset($HTTP_POST_VARS[‘authinput’])) {
if(strcmp($HTTP_POST_VARS[‘authnum’],$HTTP_POST_VARS[‘authinput’])==0)
echo “验证成功!”; else echo “验证失败!”; } //生成新的四位整数验证码
while%10000)<1000); ?>

代码二:

修改后的代码如下:

ImagePNG; ImageDestroy; ?>

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

//生成验证码图片 Header(“Content-type: image/PNG”); srand*1000000); $im
= imagecreate; $black = ImageColorAllocate; $white = ImageColorAllocate;
$gray = ImageColorAllocate; imagefill;

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

本站注:作者使用了简单的代码实现了很酷的功能。不过在添加干扰像素时的效果不是太好,大家可以看一下雨声论坛登录时的效验码(

新澳门31999,srand*1000000);

代码一:

for //加入干扰象素 { imagesetpixel%70 , rand; }

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

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

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

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

发表评论

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