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

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

缺陷编号: WooYun-2014-58479

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

相关厂商: zuitu.com

漏洞作者: ′雨。认证白帽子

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

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

漏洞类型: SQL注射漏洞

危害等级: 高

自评Rank: 20

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

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

Tags标签: 无

6人收藏 收藏
分享漏洞:


漏洞详情

披露状态:

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

简要描述:

最土团购在我印象中 用得还是有把。

至少我自己都遇到过几次了。

前段时间挖的了。 本来想留着自己玩的。

可是留着留着也没用过, 忘记了自己早已不搞站。

还是发出来把。

注入可提升自己为管理 & 给自己刷100万可好?

无视GPC。

详细说明:

在order/chinabank/notify.php中



code 区域
$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

code 区域
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 里面的都被单引号了。 而且如果我们提交单引号的话还会被转义。

code 区域
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:此产品已不再维护,原站已经下线,感谢白帽子提交漏洞,中国因你们更精彩


漏洞评价:

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

漏洞评价(共0人评价):
登陆后才能进行评分

评价

  1. 2014-04-25 21:44 | ( 普通白帽子 | Rank:1218 漏洞数:107 | 传闻中魇是一个惊世奇男子, 但是除了他华...)
    1

    最土团购..这名..真的 土爆了..

  2. 2014-04-25 21:46 | 鬼魅羊羔 ( 普通白帽子 | Rank:299 漏洞数:42 | (#‵′)凸(#‵′)凸(#‵′)凸(#‵′)凸(#‵...)
    0

    尖刀的小伙伴~~

  3. 2014-04-25 21:46 | 疯子 ( 普通白帽子 | Rank:259 漏洞数:45 | 世人笑我太疯癫,我笑世人看不穿~)
    1

    你以为乌云上真有那么多白帽子提交漏洞?太天真了,全是我小号,不信我换一个号提交漏洞!

  4. 2014-04-25 21:47 | 鬼魅羊羔 ( 普通白帽子 | Rank:299 漏洞数:42 | (#‵′)凸(#‵′)凸(#‵′)凸(#‵′)凸(#‵...)
    0

    @疯子 你妹!(保持队形!)

  5. 2014-04-25 21:50 | zcy ( 实习白帽子 | Rank:93 漏洞数:15 )
    0

    @鬼魅羊羔 你妹!!(保持队形!)

  6. 2014-04-25 21:52 | Hero ( 普通白帽子 | Rank:145 漏洞数:43 | 药药切克闹,充气娃娃迷幻药)
    0

    @zcy 你妹!!!(保持队型)

  7. 2014-04-25 22:03 | Lonely ( 实习白帽子 | Rank:80 漏洞数:30 | 人生如梦,始终都游不过当局者迷的悲哀。)
    0

    @Hero 你妹!!!(保持队型)

  8. 2014-04-25 22:19 | 楼下小黑 ( 路人 | Rank:0 漏洞数:1 | 高智商白痴)
    0

    @Lonely 你妹!!!(保持队型)

  9. 2014-04-25 22:21 | 漫步云端 ( 普通白帽子 | Rank:216 漏洞数:39 | Ramble!)
    0

    @楼下小黑 你妹!!!(保持队型)

  10. 2014-04-25 22:25 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    。。破坏队形。

  11. 2014-04-25 22:41 | Bird ( 实习白帽子 | Rank:60 漏洞数:25 | Stay hungry. Stay foolish.)
    0

    @′ 雨。 你妹!!!(恢复队形)

  12. 2014-04-25 22:53 | 小威 ( 普通白帽子 | Rank:531 漏洞数:86 | 活到老,学到老!)
    0

    @Bird 你妹!!!(专业维持队形)

  13. 2014-04-25 22:55 | 土豪 ( 路人 | Rank:16 漏洞数:6 | 我是土豪却没有5WB)
    0

    打乱队形

  14. 2014-04-25 22:57 | 鬼魅羊羔 ( 普通白帽子 | Rank:299 漏洞数:42 | (#‵′)凸(#‵′)凸(#‵′)凸(#‵′)凸(#‵...)
    0

    @土豪 你妹!!!(恢复队形)

  15. 2014-04-25 22:57 | nextdoor ( 普通白帽子 | Rank:332 漏洞数:75 | Just for fun)
    0

    再打乱队形

  16. 2014-04-25 23:06 | Hero ( 普通白帽子 | Rank:145 漏洞数:43 | 药药切克闹,充气娃娃迷幻药)
    0

    @nextdoor 你妹!!!(wooyun自动恢复)

  17. 2014-04-25 23:33 | Summer ( 普通白帽子 | Rank:458 漏洞数:101 | 万年普通白帽子)
    0

    忽略

  18. 2014-04-26 00:12 | 好人 ( 路人 | Rank:13 漏洞数:6 | 多少人曾爱慕你年轻的容颜)
    0

    @Summer 你妹!!!(wooyun自动恢复)

  19. 2014-04-26 00:13 | 熊猫 ( 实习白帽子 | Rank:64 漏洞数:33 | panda)
    0

    网站都打不开

  20. 2014-04-26 00:26 | 寂寞的瘦子 ( 普通白帽子 | Rank:242 漏洞数:53 | ☯☯☯☯☯☯☯☯☯☯)
    0

    @熊猫 你妹!!!(已经自动fix bug)

  21. 2014-04-26 01:42 | hacker@sina.cn ( 普通白帽子 | Rank:288 漏洞数:27 | ANONYMOUS)
    0

    官网都没了 呵呵呵 我的shell啊 唉...

  22. 2014-04-26 04:46 | Cougar ( 实习白帽子 | Rank:69 漏洞数:19 | 不容易。)
    0

    牛阿

  23. 2014-04-26 08:49 | JiuShao ( 普通白帽子 | Rank:493 漏洞数:107 | ╮(╯▽╰)╭锄禾日当午)
    0

    叼,坐等忽略。

  24. 2014-04-26 10:10 | 小博博 ( 实习白帽子 | Rank:80 漏洞数:14 | 工作)
    0

    @大神 你妹 (专业恢复队形500年)

  25. 2014-04-26 10:10 | 马云 ( 路人 | Rank:10 漏洞数:5 | 啪啪啪啪啪啪啪啪)
    0

    @寂寞的瘦子 你妹!!!

  26. 2014-04-26 12:22 | Master ( 实习白帽子 | Rank:33 漏洞数:10 )
    0

    @马云 你妹!!!

  27. 2014-04-26 13:03 | zcy ( 实习白帽子 | Rank:93 漏洞数:15 )
    0

    @Master 你妹!!!

  28. 2014-04-27 11:47 | 走火入魔 ( 路人 | Rank:18 漏洞数:2 | 多读书,多看报,少吃零食,多睡觉。)
    0

    @′ 雨。 你妹!!!

  29. 2014-04-30 19:47 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    看来又要自动忽略了 5天时间是不是太短了? @疯狗

  30. 2014-04-30 19:54 | 疯狗 认证白帽子 ( 实习白帽子 | Rank:44 漏洞数:2 | 阅尽天下漏洞,心中自然无码。)
    0

    @′ 雨。 一周时间就给厂商进行个漏洞确认操作,真心话不短啊

  31. 2014-04-30 19:57 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    @疯狗 额5天。我感觉是不是有些厂商都没看到邮件的 我猜测的是不是在自动忽略过后乌云会给厂商再发邮件。 有几次都是漏洞自动忽略没多久厂商就来回复了。 为什么不在自动忽略前不久来自动发个邮件呢。

  32. 2014-04-30 19:58 | 疯狗 认证白帽子 ( 实习白帽子 | Rank:44 漏洞数:2 | 阅尽天下漏洞,心中自然无码。)
    0

    @′ 雨。 一般情况下厂商看到了,但是处理问题是最优先的事情,然后乌云的确认就被遗忘了

  33. 2014-04-30 19:59 | 疯狗 认证白帽子 ( 实习白帽子 | Rank:44 漏洞数:2 | 阅尽天下漏洞,心中自然无码。)
    0

    @′ 雨。 这块我看看在加一次提醒吧,比如5天即将公开的时候,第四天在发封邮件这种

  34. 2014-04-30 20:05 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    @疯狗 嗯 这再好不过了,

  35. 2014-04-30 21:50 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    唉 又自动被忽略了 狗哥来补点分撒 @疯狗

  36. 2014-05-19 17:12 | 疯狗 认证白帽子 ( 实习白帽子 | Rank:44 漏洞数:2 | 阅尽天下漏洞,心中自然无码。)
    1

    @′ 雨。 最土已经停止维护了啊。。

  37. 2014-05-19 17:18 | 寂寞的瘦子 ( 普通白帽子 | Rank:242 漏洞数:53 | ☯☯☯☯☯☯☯☯☯☯)
    0

    @疯狗 中国因为你们更精彩

  38. 2014-05-19 17:34 | ′ 雨。 认证白帽子 ( 普通白帽子 | Rank:1332 漏洞数:198 | Only Code Never Lie To Me.)
    0

    @疯狗 这蛋疼,,。。 狗哥这样得就没奖金了吧?

  39. 2014-05-19 18:26 | 疯狗 认证白帽子 ( 实习白帽子 | Rank:44 漏洞数:2 | 阅尽天下漏洞,心中自然无码。)
    0

    @′ 雨。 如果还有很多用户的话还是会给奖励,另外你这个有技术亮点啊,淫荡的提权,所以还是有奖金的

  40. 2014-05-20 12:41 | 熊猫 ( 实习白帽子 | Rank:64 漏洞数:33 | panda)
    0

    人家。。都不开网站了

  41. 2014-06-19 23:27 | Walle ( 路人 | Rank:0 漏洞数:5 | ... 位卑、未敢忘忧国! ...)
    0

    小菜还是不会利用啊、哪位大神教教啊、、

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