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

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

缺陷编号:wooyun-2014-058479

漏洞标题:最土团购注入一枚可直接提升自己为管理 & 无限刷钱。

相关厂商:zuitu.com

漏洞作者: ′雨。

提交时间:2014-04-25 21:43

修复时间:2014-07-23 18:34

公开时间:2014-07-23 18:34

漏洞类型:SQL注射漏洞

危害等级:高

自评Rank:20

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

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

Tags标签:

4人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

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

简要描述:

最土团购在我印象中 用得还是有把。
至少我自己都遇到过几次了。
前段时间挖的了。 本来想留着自己玩的。
可是留着留着也没用过, 忘记了自己早已不搞站。
还是发出来把。
注入可提升自己为管理 & 给自己刷100万可好?
无视GPC。

详细说明:

在order/chinabank/notify.php中

$key = $INI['chinabank']['sec'];
$v_oid = trim($_POST['v_oid']); // 商户发送的v_oid定单编号
$v_pmode = trim($_POST['v_pmode']); // 支付方式(字符串)
$v_pstatus = trim($_POST['v_pstatus']); //支付状态 :20 成功,30 失败
$v_pstring = trim($_POST['v_pstring']); // 支付结果信息
$v_amount = trim($_POST['v_amount']); // 订单实际支付金额
$v_moneytype = trim($_POST['v_moneytype']); //订单实际支付币种
$remark1 = trim($_POST['remark1' ]); //备注字段1
$remark2 = trim($_POST['remark2' ]); //备注字段2
$v_md5str = trim($_POST['v_md5str' ]); //拼凑后的MD5校验值
/* 重新计算md5的值 */
$text = "{$v_oid}{$v_pstatus}{$v_amount}{$v_moneytype}{$key}";
$md5string = strtoupper(md5($text));
/* 判断返回信息,如果支付成功,并且支付结果可信,则做进一步的处理 */
if ($v_md5str == $md5string) {
list($_, $order_id, $city_id, $_) = explode('-', $v_oid, 4);
if($v_pstatus=="20") {
/* charge */
if ( $_ == 'charge' ) {
@list($_, $user_id, $create_time, $_) = explode('-', $v_oid, 4);


ZFlow::CreateFromCharge($v_amount, $user_id, $create_time, 'chinabank');
die('ok');
}


key是空的 不用管他。 只是一点点的验证。 MD5相等可好, 然后把v_oid用来切割。
然后带入CreateFromCharge

static public function CreateFromCharge($money,$user_id,$time,$service='alipay',$trade_no=''){
global $option_service;
if (!$money || !$user_id || !$time) return 0;

$pay_id = "charge-{$user_id}-{$time}";
$pay = Table::Fetch('pay', $pay_id);
if ( $pay ) return 0;

$order_id = ZOrder::CreateFromCharge($money,$user_id,$time,$service);
if (!$order_id) return 0;
//insert pay record
$pay = array(
'id' => $pay_id,
'vid' => $trade_no,
'order_id' => $order_id,
'bank' => $option_service[$service],
'currency' => 'CNY',
'money' => $money,
'service' => $service,
'create_time' => $time,
);
DB::Insert('pay', $pay);
ZCredit::Charge($user_id, $money);
//end//
//update user money;

$user = Table::Fetch('user', $user_id);

Table::UpdateCache('user', $user_id, array(
'money' => array( "money + {$money}" ),
));
$u = array(
'user_id' => $user_id,
'admin_id' => 0,
'money' => $money,
'direction' => 'income',
'action' => 'charge',
'detail_id' => $pay_id,
'create_time' => $time,
);
return DB::Insert('flow', $u);
}


这里有一个insert 语句 和一个update语句。
insert 里面的都被单引号了。 而且如果我们提交单引号的话还会被转义。

Table::UpdateCache('user', $user_id, array(
'money' => array( "money + {$money}" ),
));


看这个update $money是没有单引号的。
然后带入查询 首先构造一下语句。
由于 管理和用户都是在user表里 是通过manager这个column 用来判断是否为管理员。
我们给我们自己的用户的manager update成y 即可成为管理员。
UPDATE `user` SET `money`=money + asd WHERE `id`='88'
执行的语句如此。 我们构造一下语句。

漏洞证明:

z1.jpg


z2.jpg


成功提升。
百度随便找了个站测试。

251959241d8209af5fa2fb1b5cfea0f3f3f7fa2a.jpg


无限刷钱

z4.jpg


成功提升。

修复方案:

过滤。

版权声明:转载请注明来源 ′雨。@乌云


漏洞回应

厂商回应:

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

忽略时间:2014-07-23 18:34

厂商回复:

最新状态:

2014-05-19:此产品已不再维护,原站已经下线,感谢白帽子提交漏洞,中国因你们更精彩