Warning: session_start() [function.session-start]: open(/home/mybwtech/public_html/article/tmp/sess_8dc3fa8faf39ab88665b8f218b339a04, O_RDWR) failed: No such file or directory (2) in /home/mybwtech/public_html/article/global.php on line 3

Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent by (output started at /home/mybwtech/public_html/article/global.php:3) in /home/mybwtech/public_html/article/global.php on line 3

Warning: session_start() [function.session-start]: Cannot send session cache limiter - headers already sent (output started at /home/mybwtech/public_html/article/global.php:3) in /home/mybwtech/public_html/article/global.php on line 3
利用PHP实现验证码的方法 - 龙舞天翔资源共享
我的控制台 会员登陆 免费注册 最后更新 高级搜索 返回首页 我要投稿 退出登陆 龙舞论坛
当前在线: 0
 
站内搜索
Google
www.bwtech.net

德州扑克资料
投资透视
网站优化推广&SEO
网站设计
网络编程语言与开发
课件开发制作
网络文学
小资生活
数码摄影
财经-经营管理
其他杂项
龙舞天翔资源共享 / 网络编程语言与开发 / PHP语言技术 / 利用PHP实现验证码的方法
利用PHP实现验证码的方法
2004-12-17          点击: 1613
利用PHP实现验证码的方法

前段时间看了一些关于验证码的文章,就是将一串随机产生的数字或符号,生成一幅图片,图片里加上一些干扰象素(防止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">

<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 onsubmit="return check();">

<table>

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

<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 &amp;&amp; $num<>""){

echo "验证成功";

}else{

echo "验证失败";

}

?>

写这篇文章我也是很郁闷的心情,在google用“验证码+php”搜索到只有那篇文章,就是找不出个实用点的。没办法,虽然外语水平一般,还是忍痛用了全英文搜索,找到了了不知道哪个国家的程序员写的一段代码,我把变量换成国人容易看懂的形式,这就是我做的。真的很希望下次用中文也能搜索出点有深度的文章教程,不是说提倡资源共享的么……

 

责任编辑: 龙舞天翔

相关文章
关于phpArticle后台无法登陆的问题 - 02-24 10:23 am - 点击: 481
php 实现无限分类 - 07-14 01:25 am - 点击: 1496
ASP,PHP,JSP各自的优点和缺点 - 03-05 10:47 pm - 点击: 2068
提升PHP速度全攻略 - 02-09 04:42 am - 点击: 1379
PHP:路在何方? - 02-09 04:37 am - 点击: 1425
PHP编码规范 - 02-09 04:33 am - 点击: 1266
PHP简介 - 02-09 04:31 am - 点击: 1679
回顾 PHP 5.0 的变化与PHP 6.0 展望 - 02-08 10:23 pm - 点击: 1448
phpArticle 首页分类调用较完美解决方案 - 12-14 05:07 am - 点击: 1577
phpArticle防止图片盗链的方法 - 12-11 11:04 am - 点击: 1616

发表评论 查看评论 加入收藏 Email给朋友 打印本文
如果你想对该文章评分, 请先登陆, 如果你仍未注册,请点击注册链接注册成为本站会员.
平均得分 0, 共 0 人评分
1 2 3 4 5 6 7 8 9 10
Copyright © 2002 -2003 龙舞天翔资源共享
All rights reserved.
Powered by: phpArticle Version 2.0

Warning: Unknown: open(/home/mybwtech/public_html/article/tmp/sess_8dc3fa8faf39ab88665b8f218b339a04, O_RDWR) failed: No such file or directory (2) in Unknown on line 0

Warning: Unknown: Failed to write session data (files). Please verify that the current setting of session.save_path is correct (/home/mybwtech/public_html/article/tmp) in Unknown on line 0