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

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

缺陷编号:wooyun-2012-05980

漏洞标题:骑士cms任意目录打包下载漏洞。。。

相关厂商:74c,s.com

漏洞作者: 猪头子

提交时间:2012-04-23 14:21

修复时间:2012-06-07 14:21

公开时间:2012-06-07 14:21

漏洞类型:敏感信息泄露

危害等级:中

自评Rank:10

漏洞状态:厂商已经确认

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

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

2012-04-23: 细节已通知厂商并且等待厂商处理中
2012-04-23: 厂商已经确认,细节仅向厂商公开
2012-04-26: 细节向第三方安全合作伙伴开放
2012-06-17: 细节向核心白帽子及相关领域专家公开
2012-06-27: 细节向普通白帽子公开
2012-07-07: 细节向实习白帽子公开
2012-06-07: 细节向公众公开

简要描述:

74cms_v3.1.20120214中任意web目录打包下载。。。很有意思的漏洞

详细说明:

74cms后台有一个备份模板的功能,程序会自动备份选中的模板并压缩下载,但是没有对用户提交的$tpl变量进行检查就带入函数,导致构造变量即可打包任意目录并下载。。
看代码。。在admin/admin_template.php 第47行

elseif ($act == 'backup')
{
check_token();
check_permissions($_SESSION['admin_purview'],"tpl_backup");
require_once(ADMIN_ROOT_PATH.'include/admin_phpzip.php');
$tpl = trim($_REQUEST['tpl_name']);
//$filename受$tpl影响
$filename = '../temp/backup_templates/' . $tpl . '_' . date('Ymd') . '.zip';
$zip = new PHPZip;
//没有检查tpl_name的有效性就直接调用zip进行压缩
//由于$filename也受$tpl控制,导致如果遍历层数大于三层web程序会把压缩文件
//放入web目录外。。
$done = $zip->zip('../templates/' . $tpl . '/', $filename);
if ($done)
{
header("Location:".$filename."");
}
else
{
adminmsg("操作失败!",0);
}
}

漏洞证明:


更改tpl_name,我们下载data文件夹





修复方案:

过滤吧亲

版权声明:转载请注明来源 猪头子@乌云


漏洞回应

厂商回应:

危害等级:低

漏洞Rank:5

确认时间:2012-04-23 16:23

厂商回复:

添加对漏洞的补充说明以及做出评价的理由

最新状态:

暂无