帝国软件
  设为首页 加入收藏 关于我们
 
解密帝国网站管理系统
栏 目:
 
您的位置:首页 > 技术文档 > PHP编程
利用PHP实现验证码的方法
作者:佚名 发布时间:2005-04-02 来源:不详
 前段时间看了一些关于验证码的文章,就是将一串随机产生的数字或符号,生成一幅图片,图片里加上一些干扰象素(防止OCR),由用户肉眼识别其中的验证码信息,输入表单提交网站验证,验证成功后才能使用某项功能。 有篇文章也简单的介绍了实现的方法,如下: 代码一: /* * 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); ?> 请输入验证码: > >   代码二: /* * 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 请输入验证码: /* * 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); ?> /* * Filename:authpage.php */ session_start(); $num=trim($num); if($auth_num==$num && $num<>""){ echo "验证成功"; }else{ echo "验证失败"; } ?> 写这篇文章我也是很郁闷的心情,在google用“验证码+php”搜索到只有那篇文章,就是找不出个实用点的。没办法,虽然外语水平一般,还是忍痛用了全英文搜索,找到了了不知道哪个国家的程序员写的一段代码,我把变量换成国人容易看懂的形式,这就是我做的。真的很希望下次用中文也能搜索出点有深度的文章教程,不是说提倡资源共享的么……
  
评论】【加入收藏夹】【 】【打印】【关闭
※ 相关链接
 ·利用网址传送资料  (2005-04-02)
 ·利用SQL 数据操作组件和MS SQL S  (2005-04-02)
 ·利用关联将子关联记录取出  (2005-04-02)
 ·利用JSP 2.0开发Web应用程序  (2005-04-02)
 ·如何利用JSP连接数据库大全  (2005-04-02)
 ·如何利用JSP的9种基本内置组件  (2005-04-02)
 ·利用JSP“抓”网页代码的程序  (2005-04-02)
 ·如何利用Jsp分页实例的代码  (2005-04-02)
 ·如何正确利用 J2EE 的各种工具  (2005-04-02)
 ·利用ASP规划聊天室  (2005-03-12)

   栏目导行
  PHP编程
  ASP编程
  ASP.NET编程
  JAVA编程
   站点最新
·致合作伙伴的欢迎信
·媒体报道
·帝国软件合作伙伴计划协议
·DiscuzX2.5会员整合通行证发布
·帝国CMS 7.0版本功能建议收集
·帝国网站管理系统2012年授权购买说
·PHPWind8.7会员整合通行证发布
·[官方插件]帝国CMS-访问统计插件
·[官方插件]帝国CMS-sitemap插件
·[官方插件]帝国CMS内容页评论AJAX分
   类别最新
·Windows下集成安装Apache,PHP,MYSQ
·Mysql注入:SQL Injection with MyS
·PHP 的来龙去脉
·PHP 的功能概述
·PHP与其它CGI的比较
·PHP 的编译配置详细选项
·php.ini 配置详细选项
·如何写作PHP程序
·Hello,World
·嵌入方法
 
关于帝国 | 广告服务 | 联系我们 | 程序开发 | 网站地图 | 留言板 帝国网站管理系统