当前位置:WooYun >> 漏洞信息

漏洞概要 关注数(24) 关注此漏洞

缺陷编号:wooyun-2014-060192

漏洞标题:mcms手机建站之星设计缺陷导致数据库被下载

相关厂商:mcms.cc

漏洞作者: phith0n

提交时间:2014-05-12 11:35

修复时间:2014-08-07 11:36

公开时间:2014-08-07 11:36

漏洞类型:设计缺陷/逻辑错误

危害等级:中

自评Rank:20

漏洞状态:漏洞已经通知厂商但是厂商忽略漏洞

漏洞来源: http://www.wooyun.org,如有疑问或需要帮助请联系 [email protected]

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

2014-05-12: 细节已通知厂商并且等待厂商处理中
2014-05-12: 厂商主动忽略漏洞,细节向第三方安全合作伙伴开放
2014-07-06: 细节向核心白帽子及相关领域专家公开
2014-07-16: 细节向普通白帽子公开
2014-07-26: 细节向实习白帽子公开
2014-08-07: 细节向公众公开

简要描述:

相比于之前的文件包含,这个影响更严重吧

详细说明:

mcms后台dbbak.php,是对数据库进行备份处理的文件
304行,备份具体表:

$handle = fopen($dbkdir . $tablename . "_" . $pageid . ".sql.","wb");
fputs($handle, $bakupdata);
fclose($handle);
unset($bakupdata);
$selfurl = "dbbak.php?m=save&tableid=".$tableid."&startid=".($startid)."&pageid=".($pageid+1)."&table=$tables";
echo ('<script type="text/javascript">setTimeout(function(){window.location.href="' . $selfurl . '";},1000);</script>');
echo '<br />';
echo "正在备份数据表 <font color='red'>".$tablename."</font> 信息,当前已经写入第 ".($pageid+1)." 页,即将写入第 ".($pageid+2)." 页信息";
die();


我们可以看到,文件名直接是$dbkdir . $tablename . "_" . $pageid . ".sql
$pageid是分页,$tablename是表名,$dbdir是目录名。
如果数据库进行了备份,我们可以直接猜测到备份文件名称,然后进行下载。

漏洞证明:

装好系统后,我在后台进行一次备份。
然后来到backup目录:

02.jpg


看到各个表的备份已经躺在那里了,文件名没有任何随机字符串
管理员密码就在mcms_admin_list_0.sql中:

03.jpg


随便找了一个使用该系统的网站验证,可以下载数据库备份拉:
http://www.ydfsmj.com/backup/mcms_admin_list_0.sql

修复方案:

数据库备份文件名请随机命名

版权声明:转载请注明来源 phith0n@乌云


漏洞回应

厂商回应:

危害等级:无影响厂商忽略

忽略时间:2014-08-07 11:36

厂商回复:

已提供新的修复代码

最新状态:

暂无


漏洞评价:

评论

  1. 2014-05-12 22:36 | phith0n 认证白帽子 ( 核心白帽子 | Rank:656 漏洞数:107 | 一个想当文人的黑客~)

    修复为啥不确认呢?