php你的验证码安全码?


Posted in PHP onJanuary 02, 2007

验证码的作用主要有防止暴力破解,防止恶意灌水,防止自动提交等,在这里我就不多说了。验证码的类型也有数字、字母等,甚至厉害点的还有中文的。但是不管你的验证码多么厉害,只要你在表单验证中存在如下的失误,你的验证码就形同虚设!

验证码的一般思路,就是每次登陆的地方访问一个脚本文件,该文件生成含验证码的图片并将值写入到Session里,提交的时候验证登陆的脚本就会判断提交的验证码是否与Session里的一致。

问题出现了,在登陆密码错误之后,我们不去访问生成验证图片的文件,那么如果Session中的验证码没有被清空,此时验证码就是跟上次的一样,辛辛苦苦构建的验证码机制就形同虚设了。

下面我们先来看一段有问题的代码:
登陆部分:

CODE:
<tr>
          <
td>管理员姓名:td>
          <
td><input type="text" name="username" />td>
      tr>
      <
tr>
          <
td>管理员密码:td>
          <
td><input type="password" name="password" />td>
      tr>
            <
tr>
          <
td>验证码:td>
          <
td><input type="text" name="captcha" onkeyup="pressCaptcha(this)" />td>
      tr>
      <
tr>
      <
td colspan="2" align="right">
      <
img src="index.php?act=captcha&1628020115" width="145" height="20" alt="CAPTCHA" border="1" onclickthis.src="index.php?act=captcha&"+Math.random() style="cursor: pointer;" title="看不清?点击更换另一个验证码。" />
      td>
      tr>
?>
这里没什么问题,来看登陆验证的代码(我想这样的验证思路,也是大多数人都在用的吧):
CODE:
/*------------------------------------------------------ */
//-- 验证登陆信息
/*------------------------------------------------------ */
if ($_REQUEST['act'] == 'signin')
{
    include(
'../includes/cls_captcha.php');

   

/* 检查验证码是否正确 */
   
$validator = new captcha();
   if (!
$validator->check_word($_POST['captcha']))
   {
       
sys_msg($_LANG['captcha_error'], 1);
    }

    

/* 检查密码是否正确 */
    
$sql "SELECT user_id, user_name, password, action_list FROM " .$ecs->table('admin_user'). 
            
" WHERE user_name='$_POST[username]' AND password='" .md5($_POST['password']). "'";
    
$row $db->GetRow($sql);

    if (

$row)
    {
        
// 登录成功
        
set_admin_session($row['user_id'], $row['user_name'], $row['action_list']);

        

// 更新最后登录时间和IP
        
$db->Execute("UPDATE " .$ecs->table('admin_user'). 
                    
" SET last_time='" .date('Y-m-d H:i:s'time()). "', last_ip='" .real_ip(). "'".
                    
" WHERE user_id=$_SESSION[admin_id]") OR die($db->ErrorMsg());

        if (isset(

$_POST['remember']))
        {
            
setcookie('ECSCP[admin_id]',    $row[0], time() + 3600 24 360);
            
setcookie('ECSCP[admin_pass]',  md5($row['password'] . $_CFG['hash_code']), time() + 3600 24 360);
        }

        

header('location:./');
    }
    else
    {
        
sys_msg($_LANG['login_faild'], 1);
    }
}
?>
问题就出在上面这段代码里,在检查密码错误之后,并没有更新验证码,这样我们就可以把登陆页面的验证码图片部分去掉,而只要用URL访问一下验证码的页面,就可以只提交用户名、密码、刚才得到的验证码实现暴力破解了,利用此方法,同样可以实现灌水,刷票等。
大家可以看下面的图片,增强点直观的认识。
php你的验证码安全码?

解决方法:我们需要在检查密码错误后更新验证码,对于留言等类型的,还要在提交成功后更新验证码。

安全就是这样,我们总是想让自己的程序更安全,但是一般情况下,我们又总是走在常规思维里跳不出来,于是导致我们的程序出现了很多"非常规漏洞",或者叫做"缺陷",总之就是不完美。我写这篇文章除了指出上面这个问题之外,还希望大家都能行动起来,用"非常规"眼光,重新检查下自己的程序,把更多以前自己没有发现的小问题帖出来,让大家共同提高!

PHP 相关文章推荐
解析php中两种缩放图片的函数,为图片添加水印
Jun 14 PHP
利用phpexcel把excel导入数据库和数据库导出excel实现
Jan 09 PHP
php curl请求信息和返回信息设置代码实例
Apr 27 PHP
Zend Framework教程之Application和Bootstrap用法详解
Mar 10 PHP
php利用gd库为图片添加水印
Nov 09 PHP
PHP正则表达式匹配替换与分割功能实例浅析
Feb 04 PHP
详解Yii2.0 rules验证规则集合
Mar 21 PHP
PHP面向对象五大原则之开放-封闭原则(OCP)详解
Apr 04 PHP
PHP多进程通信-消息队列使用
Mar 08 PHP
PHP goto语句用法实例
Aug 06 PHP
php的对象传值与引用传值代码实例讲解
Feb 26 PHP
PHP7 参数处理机制修改
Mar 09 PHP
一个PHP操作Access类(PHP+ODBC+Access)
Jan 02 #PHP
一个用php实现的获取URL信息的类
Jan 02 #PHP
PHP 和 MySQL 开发的 8 个技巧
Jan 02 #PHP
Smarty结合Ajax实现无刷新留言本实例
Jan 02 #PHP
Ajax PHP分页演示
Jan 02 #PHP
windows下PHP APACHE MYSQ完整配置
Jan 02 #PHP
PHP Ajax实现页面无刷新发表评论
Jan 02 #PHP
You might like
详细介绍PHP应用提速面面观
2006/10/09 PHP
PHP类的静态(static)方法和静态(static)变量使用介绍
2012/02/19 PHP
浅析php变量修饰符static的使用
2013/06/28 PHP
PHP生成自适应大小的缩略图类及使用方法分享
2014/05/06 PHP
Codeigniter生成Excel文档的简单方法
2014/06/12 PHP
php自动提交表单的方法(基于fsockopen与curl)
2016/05/09 PHP
用客户端js实现带省略号的分页
2013/04/27 Javascript
JavaScript的面向对象编程基础
2015/08/13 Javascript
js实现简单计算器
2015/11/22 Javascript
神奇!js+CSS+DIV实现文字颜色渐变效果
2016/03/16 Javascript
全面接触神奇的Bootstrap导航条实战篇
2016/08/01 Javascript
JavaScript面向对象编写购物车功能
2016/08/19 Javascript
js处理层级数据结构的方法小结
2017/01/17 Javascript
JavaScript 网页中实现一个计算当年还剩多少时间的倒数计时程序
2017/01/25 Javascript
vue省市区三联动下拉选择组件的实现
2017/04/28 Javascript
JavaScript自执行函数和jQuery扩展方法详解
2017/10/27 jQuery
vue 挂载路由到头部导航的方法
2017/11/13 Javascript
vue检测对象和数组的变化分析
2018/06/30 Javascript
vue做移动端适配最佳解决方案(亲测有效)
2018/09/04 Javascript
JavaScript指定断点操作实例教程
2018/09/18 Javascript
详解vue 路由跳转四种方式 (带参数)
2019/04/28 Javascript
剖析Django中模版标签的解析与参数传递
2015/07/21 Python
Python动态生成多维数组的方法示例
2018/08/09 Python
Python 脚本获取ES 存储容量的实例
2018/12/27 Python
Python实现简易过滤删除数字的方法小结
2019/01/09 Python
pytorch: Parameter 的数据结构实例
2019/12/31 Python
Pycharm激活方法及详细教程(详细且实用)
2020/05/12 Python
Python如何使用vars返回对象的属性列表
2020/10/17 Python
Python爬虫模拟登陆哔哩哔哩(bilibili)并突破点选验证码功能
2020/12/21 Python
解决virtualenv -p python3 venv报错的问题
2021/02/05 Python
介绍CSS3使用技巧5个
2009/04/02 HTML / CSS
英国最大的在线快递公司之一:ParcelHero
2019/11/04 全球购物
审计工作个人的自我评价
2013/12/25 职场文书
PostgreSQL存储过程实用脚本(二):创建函数入门
2021/04/05 PostgreSQL
详解Python类和对象内容
2021/06/22 Python
详解Vue3使用axios的配置教程
2022/04/29 Vue.js