原文来自:https://www.zixuephp.com

dedecms安全配置,添加登录管理认证码

dede用的人越来越多,也就引来各种关注,然后就各种漏洞、入侵,最近又爆出了一个堪称全版本都有的漏洞,的确,我googlehack了一下,基本上 5.5-5.7 的版本测试都可以,不过MD5是个硬伤,多余的话就不说了.

其实就是在后台登录界面添加个表单验证而已,管理认证,应该知道吧,动易、帝国的那种,本地字符验证,而不是数据库验证,所以SQL查询不了,入侵时碰到这种登录最纠结,最无奈的.

首先看看,我们要改的是这2个文件/(后台路径)/templets/login.htm 这是后台登录界面,/(后台路径)/login.php 登录消息的处理文件.

我们先来改login.htm文件,可能大家的模板不一样,不过自己改改吧,这是验证表单是否为空的代码,可以直接放在HTML里,也可以link到JS文件里,代码如下:

  1. <scriptlanguage="javascript">
  2. <!–
  3. varclosestr=0;
  4. functionSetFocus(){
  5. vardf=document.form1;
  6. if(df.userid.value=='')
  7. df.userid.focus();
  8. else
  9. df.userid.select();
  10. }
  11. functionCheckForm(){
  12. vardf=document.form1;
  13. if(df.userid.value==''){
  14. alert('请输入用户名!');
  15. df.userid.focus();
  16. returnfalse;
  17. }
  18. if(df.pwd.value==''){
  19. alert('请输入密码!');
  20. df.pwd.focus();
  21. returnfalse;
  22. }
  23. if(df.validate.value==''){
  24. alert('请输入您的验证码!');
  25. df.validate.focus();
  26. return(false);
  27. }
  28. if(df.vacodes.value==''){
  29. alert('请输入您的认证码!');
  30. df.vacodes.focus();
  31. return(false);
  32. }
  33. }
  34. //–>
  35. </script>

这是我的form框架和input提交,其实那个认证码的input 直接复制用户名的 input或密码的input就可以,改下name名就可以了,代码如下:

  1. <formname="form1"id="form1"method="post"action="login.php"onsubmit='returnCheckForm();'>
  2. <inputtype="hidden"name="gotopage"value="<?phpif(!empty($gotopage))echo$gotopage;?>"/>
  3. <inputtype="hidden"name="dopost"value="login"/>
  4. <ul>
  5. <li><span>用户名:</span>
  6. <inputtype="text"name="userid"class="input_out"maxlength="20"style="width:148px;"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'"/>
  7. </li>
  8. <li><span>密&nbsp;&nbsp;码:</span>
  9. <inputtype="password"name="pwd"class="input_out"maxlength="20"style="width:148px;"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'"/>
  10. </li>
  11. <li><span>认证码:</span>
  12. <inputtype="password"name="vacodes"class="input_out"maxlength="20"style="width:148px;"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'"/>
  13. </li>
  14. <li><span>验证码:</span>
  15. <inputname="validate"type="text"id="vdcode"style="width:50px;text-transform:uppercase;"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'"class="input_out"/>
  16. <imgid="vdimgck"src="../include/vdimgck.php"alt="看不清?点击更换"align="absmiddle"style="cursor:pointer"onclick="this.src=this.src+'?'"/></li>
  17. <span>&nbsp;</span>
  18. <inputname='Submit'type='image'style='width:60px;HEIGHT:25px;'src='img/submit.gif'width='60'height='27'/>
  19. </li>
  20. </ul>
  21. </form>

然后就是提交验证(/login.php)了,代码第50行就有注释 //登录检测,我们把验证内嵌在如下代码:

  1. if(!emptyempty($userid)&&!emptyempty($pwd)){
  2. $res=$cuserLogin->checkUser($userid,$pwd);
  3. //success
  4. if($res==1){
  5. //里,如下。
  6. if(!emptyempty($userid)&&!emptyempty($pwd)){
  7. $res=$cuserLogin->checkUser($userid,$pwd);
  8. //success
  9. if($res==1){//嵌套到这里面!
  10. $uservacodes=$_POST['vacodes'];//取出vacodes内容放入另一个变量
  11. if($uservacodes!='认证码自定义'){//自行修改认证码自定义内容!
  12. ResetVdValue();
  13. ShowMsg('认证码不正确!','login.php',0,1000);//不等于跑这里
  14. die;www.111cn.net
  15. }else{//等于就跑这里
  16. $cuserLogin->keepUser();
  17. if(!emptyempty($gotopage)){
  18. ShowMsg('成功登录,正在转向管理管理主页!',$gotopage);
  19. die;
  20. }else{
  21. $uservacodes=$_POST['vacodes'];
  22. ShowMsg('成功登录,正在转向管理管理主页!','index.php');
  23. die;
  24. }
  25. }

解释:先验证图片验证码,在验证用户名,在验证密码,最后验证认证码,以免认证码被爆破.

注意:if的块语句{}一定要对应,不然会出错,可以用Notepad++来修改.

也可以把认证码比较那里设置成变量,链接到包含的文件里,比如config文件,自己操作吧,个人博客我就不讲究互动性了,其他的网站源码也大同小异,找到登录界面和提交页面,修改之即可.