网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的范文:

 

标题 dedecms添加登录管理认证码的方法
范文
    本文实例讲述了dedecms添加登录管理认证码的方法。分享给大家供大家参考。具体分析如下:
    随着dedecms用的人越来越多,也就引来各种关注,然后就各种漏洞、入侵,最近又爆出了一个堪称全版本都有的漏洞,的确,我googlehack了一下,基本上 5.5-5.7 的版本测试都可以,不过MD5是个硬伤,多余的话就不说了.
    其实就是在后台登录界面添加个表单验证而已,管理认证,应该知道吧,动易、帝国的那种,本地字符验证,而不是数据库验证,所以SQL查询不了,入侵时碰到这种登录最纠结,最无奈的.
    首先看看,我们要改的是这2个文件/(后台路径)/templets/login.htm 这是后台登录界面,/(后台路径)/login.php 登录消息的处理文件.
    我们先来改login.htm文件,可能大家的模板不一样,不过自己改改吧,这是验证表单是否为空的代码,可以直接放在HTML里,也可以link到JS文件里,代码如下:
    复制代码代码如下:<script language="javascript">
    <!--
    var closestr=0;
    function SetFocus() {
    var df = document.form1;
    if(df.userid.value == '')
    df.userid.focus();
    else
    df.userid.select();
    }
    function CheckForm() {
    var df = document.form1;
    if(df.userid.value == '') {
    alert('请输入用户名!');
    df.userid.focus();
    return false;
    }
    if(df.pwd.value == '') {
    alert('请输入密码!');
    df.pwd.focus();
    return false;
    }
    if (df.validate.value == '') {
    alert ('请输入您的验证码!');
    df.validate.focus();
    return(false);
    }
    if (df.vacodes.value == '') {
    alert ('请输入您的认证码!');
    df.vacodes.focus();
    return(false);
    }
    }
    //-->
    </script>
    这是我的form框架和input提交,其实那个认证码的input 直接复制用户名的 input或密码的input就可以,改下name名就可以了,代码如下:
    复制代码代码如下:<form name="form1" id="form1" method="post" action="login.php" onsubmit='return CheckForm();'>
    <input type="hidden" name="gotopage" value="<?php if(!empty($gotopage)) echo $gotopage;?>" />
    <input type="hidden" name="dopost" value="login"/>
    <ul>
    <li><span>用户名:</span>
    <input type="text" name="userid" maxlength="20" onfocus="this.className='input_on';this.onmouseout=''" onblur="this.className='input_off';this.onmouseout=function(){this.className='input_out'};" onmousemove="this.className='input_move'" onmouseout="this.className='input_out'"/>
    </li>
    <li><span>密&nbsp;&nbsp;码:</span>
    <input type="password" name="pwd" maxlength="20" onfocus="this.className='input_on';this.onmouseout=''" onblur="this.className='input_off';this.onmouseout=function(){this.className='input_out'};" onmousemove="this.className='input_move'" onmouseout="this.className='input_out'"/>
    </li>
    <li><span>认证码:</span>
    <input type="password" name="vacodes" maxlength="20" onfocus="this.className='input_on';this.onmouseout=''" onblur="this.className='input_off';this.onmouseout=function(){this.className='input_out'};" onmousemove="this.className='input_move'" onmouseout="this.className='input_out'"/>
    </li>
    <li><span>验证码:</span>
    <input name="validate" type="text" id="vdcode" onfocus="this.className='input_on';this.onmouseout=''" onblur="this.className='input_off';this.onmouseout=function(){this.className='input_out'};" onmousemove="this.className='input_move'" onmouseout="this.className='input_out'"/>
    <img id="vdimgck" src="../include/vdimgck.php" onclick="this.src=this.src+'?'"/></li>
    <span>&nbsp;</span>
    <input name='Submit' type='image' style='width:60px; HEIGHT: 25px;' src='img/submit.gif' width='60' height='27'/>
    </li>
    </ul>
    </form>
    然后就是提交验证(/login.php)了,代码第50行就有注释 //登录检测,我们把验证内嵌在如下代码:
    复制代码代码如下:if (!emptyempty($userid) && !emptyempty($pwd)) {
    $res = $cuserLogin->checkUser($userid, $pwd);
    //success
    if ($res == 1) {
    //里,如下。
    if (!emptyempty($userid) && !emptyempty($pwd)) {
    $res = $cuserLogin->checkUser($userid, $pwd);
    //success
    if ($res == 1) { //嵌套到这里面!
    $uservacodes = $_POST['vacodes']; //取出vacodes内容放入另一个变量
    if ($uservacodes != '认证码自定义') { //自行修改认证码自定义内容!
    ResetVdValue();
    ShowMsg('认证码不正确!', 'login.php', 0, 1000); //不等于跑这里
    die;
    } else { //等于就跑这里
    $cuserLogin->keepUser();
    if (!emptyempty($gotopage)) {
    ShowMsg('成功登录,正在转向管理管理主页!', $gotopage);
    die;
    } else {
    $uservacodes = $_POST['vacodes'];
    ShowMsg('成功登录,正在转向管理管理主页!', 'index.php');
    die;
    }
    }
    解释:先验证图片验证码,在验证用户名,在验证密码,最后验证认证码,以免认证码被爆破.
    注意:if的块语句{}一定要对应,不然会出错,可以用Notepad++来修改.
    也可以把认证码比较那里设置成变量,链接到包含的文件里,比如config文件,自己操作吧,个人博客我就不讲究互动性了,其他的网站源码也大同小异,找到登录界面和提交页面,修改之即可.
    希望本文所述对大家的dedecms建站有所帮助。
随便看

 

在线学习网范文大全提供好词好句、学习总结、工作总结、演讲稿等写作素材及范文模板,是学习及工作的有利工具。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/12/14 4:01:02