一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php你的驗(yàn)證碼安全碼?

驗(yàn)證碼的作用主要有防止暴力破解,防止惡意灌水,防止自動(dòng)提交等,在這里我就不多說了。驗(yàn)證碼的類型也有數(shù)字、字母等,甚至厲害點(diǎn)的還有中文的。但是不管你的驗(yàn)證碼多么厲害,只要你在表單驗(yàn)證中存在如下的失誤,你的驗(yàn)證碼就形同虛設(shè)!

驗(yàn)證碼的一般思路,就是每次登陸的地方訪問一個(gè)腳本文件,該文件生成含驗(yàn)證碼的圖片并將值寫入到Session里,提交的時(shí)候驗(yàn)證登陸的腳本就會(huì)判斷提交的驗(yàn)證碼是否與Session里的一致。

問題出現(xiàn)了,在登陸密碼錯(cuò)誤之后,我們不去訪問生成驗(yàn)證圖片的文件,那么如果Session中的驗(yàn)證碼沒有被清空,此時(shí)驗(yàn)證碼就是跟上次的一樣,辛辛苦苦構(gòu)建的驗(yàn)證碼機(jī)制就形同虛設(shè)了。

下面我們先來看一段有問題的代碼:
登陸部分:

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>驗(yàn)證碼: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" onclick= this.src="index.php?act=captcha&"+Math.random() style="cursor: pointer;" title="看不清?點(diǎn)擊更換另一個(gè)驗(yàn)證碼。" />
      td>
      tr>
?>這里沒什么問題,來看登陸驗(yàn)證的代碼(我想這樣的驗(yàn)證思路,也是大多數(shù)人都在用的吧):

CODE:/*------------------------------------------------------ */
//-- 驗(yàn)證登陸信息
/*------------------------------------------------------ */
if ($_REQUEST['act'] == 'signin')
{
    include('../includes/cls_captcha.php');

   /* 檢查驗(yàn)證碼是否正確 */
   $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']);

        // 更新最后登錄時(shí)間和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);
    }
}
?>問題就出在上面這段代碼里,在檢查密碼錯(cuò)誤之后,并沒有更新驗(yàn)證碼,這樣我們就可以把登陸頁面的驗(yàn)證碼圖片部分去掉,而只要用URL訪問一下驗(yàn)證碼的頁面,就可以只提交用戶名、密碼、剛才得到的驗(yàn)證碼實(shí)現(xiàn)暴力破解了,利用此方法,同樣可以實(shí)現(xiàn)灌水,刷票等。
大家可以看下面的圖片,增強(qiáng)點(diǎn)直觀的認(rèn)識(shí)。


解決方法:我們需要在檢查密碼錯(cuò)誤后更新驗(yàn)證碼,對于留言等類型的,還要在提交成功后更新驗(yàn)證碼。

安全就是這樣,我們總是想讓自己的程序更安全,但是一般情況下,我們又總是走在常規(guī)思維里跳不出來,于是導(dǎo)致我們的程序出現(xiàn)了很多"非常規(guī)漏洞",或者叫做"缺陷",總之就是不完美。我寫這篇文章除了指出上面這個(gè)問題之外,還希望大家都能行動(dòng)起來,用"非常規(guī)"眼光,重新檢查下自己的程序,把更多以前自己沒有發(fā)現(xiàn)的小問題帖出來,讓大家共同提高!

php技術(shù)php你的驗(yàn)證碼安全碼?,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 色五夜 | 免费99精品国产自在现线观看 | 黄频在线 | 色综合天天综合高清网国产 | 深夜福利一区 | 国产精品资源在线观看网站 | 欧美成人久久一级c片免费 欧美成人免费sss | 亚洲视频欧洲视频 | 国产精品第六页 | bt7086福利一区二区三区最新 | 欧美性猛交xx免费看 | 91最新在线视频 | 手机在线黄色 | 日本久久精品免视看国产成人 | 欧日韩视频777888 | 不卡国产00高中生在线视频 | 一区二区视频网 | 午夜黄色福利 | 91短视频在线观看免费最新91 | 久久久久亚洲精品影视 | 亚洲六月婷婷 | 日韩精品网址 | 国产女人综合久久精品视 | 色精品视频 | 在线观看一区二区三区四区 | 免费欧美黄色 | 中文字幕在线一区二区在线 | 国产成人精品日本亚洲专利 | 国产片在线 | 网红主播大尺度精品福利视频 | 亚洲一区二区三区网站 | 国产午夜人做人免费视频中文 | 好吊操视频 | 九一在线观看 | 亚洲国产成人资源在线软件 | 国产精久久一区二区三区 | 一道精品视频一区二区三区男同 | 一级做受毛片免费大片 | 一级风流片a级国产 | 免费国产一区二区在免费观看 | 免费色播 |