PHP实现验证码一法

原创:sandfish

 

 

前段时间看了一些关于验证码的文章,就是将一串随机产生的数字或符号,生成一幅图片,图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输入表单提交网站验证,验证成功后才能使用某项功能。

有篇文章也简单的介绍了实现的方法,如下:

代码一:



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

?>

这段程序已经基本上实现了验证码的生成和校验功能,但是文章作者不知道为什么却将验证码的内容显示在表单里了,这样的话,只是限制了用户必须输入验证码,对恶意程序却没有任何防范作用。可以说是在难为人,而不是防范攻击。

不过还好根据原作者的思路,我们可以将验证串保存在session里,这样的话,才具有一定的安全性。

代码如下:

//file:authform.php

<script language="javascript">

function check(){

if(document.forms[0].num.value==''){

alert("请输入验证码");

return false;

exit;

}

return true;

}

</script>

<form action=authpage.php method=post οnsubmit="return check();">

<table>

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

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

<img src=authimg.php>

</table>

</form>





<?php

/*

* Filename:authimg.php

*/

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

session_start();

$auth_num="";

session_register('auth_num');

$im=imagecreate(63,20);

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

$auth_num_k=md5(rand(0,9999));

$auth_num=substr($auth_num_k,17,5);

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

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

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

//ImageFill($im,63,20,$black);//这行不知道为什么在我公司的服务器上出错误,换个空间ok

imagestring($im,5,10,3,$auth_num,$gray);



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

/*

* Filename:authpage.php

*/

session_start();

$num=trim($num);

if($auth_num==$num && $num<>""){

echo "验证成功";

}else{

echo "验证失败";

}

?>

写这篇文章我也是很郁闷的心情,在google用“验证码+php”搜索到只有那篇文章,就是找不出个实用点的。没办法,虽然外语水平一般,还是忍痛用了全英文搜索,找到了了不知道哪个国家的程序员写的一段代码,我把变量换成国人容易看懂的形式,这就是我做的。真的很希望下次用中文也能搜索出点有深度的文章教程,不是说提倡资源共享的么……
阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
实现验证码功能的具体步骤如下: 1. 首先在 PHP 中生成一个随机字符串,用于生成验证码。 2. 将生成的随机字符串存储在 Session 中。 3. 在 HTML 或 PHP 页面中显示验证码图片,并将生成的随机字符串传递给验证码图片。 4. 在用户提交表单时,将用户输入的验证码与 Session 中生成的验证码进行比较,判断用户输入的验证码是否正确。 下面是一个简单的实现验证码功能的 PHP 代码示例: ``` <?php session_start(); // 生成随机字符串 $code = rand(1000,9999); // 存储随机字符串到 Session 中 $_SESSION['code'] = $code; // 创建验证码图片 $im = imagecreatetruecolor(60, 20); // 设置图片背景色 $bg_color = imagecolorallocate($im, 255, 255, 255); imagefill($im, 0, 0, $bg_color); // 设置文字颜色 $text_color = imagecolorallocate($im, 0, 0, 0); // 在图片上绘制验证码 imagestring($im, 5, 10, 3, $code, $text_color); // 发送图片头信息 header('Content-type: image/png'); // 输出图片 imagepng($im); // 释放图片内存 imagedestroy($im); ?> ``` 在 HTML 或 PHP 页面中显示验证码图片时,可以使用以下代码: ``` <img src="captcha.php" alt="验证码"> ``` 在用户提交表单时,可以使用以下代码验证用户输入的验证码是否正确: ``` session_start(); if ($_POST['code'] == $_SESSION['code']) { // 验证码正确,执行其他操作 } else { // 验证码错误,提示用户重新输入 } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lovered

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值