Struts2 s2-032远程代码执行分析

Posted FreeBuf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Struts2 s2-032远程代码执行分析相关的知识,希望对你有一定的参考价值。

1. 介绍

Struts 2是Struts的下一代产品,是在 struts 1和WebWork的技术基础上进行了合并的全新的Struts 2框架。其全新的Struts 2的体系结构与Struts 1的体系结构差别巨大。Struts 2以WebWork为核心,采用拦截器的机制来处理用户的请求,这样的设计也使得业务逻辑控制器能够与 ServletAPI完全脱离开,所以Struts 2可以理解为WebWork的更新产品。虽然从Struts 1到Struts 2有着太大的变化,但是相对于WebWork,Struts 2的变化很小。

4月15号安恒安全研究院在Struts 2上发现了一个严重的远程代码执行漏洞(CVE-2016-3081)


2. 漏洞分析

前提:开启动态方法调用。

<constant name="struts.enable.DynamicMethodInvocation" value="true" />


假如动态方法调用已经开启,然后我们要调用对应的login方法的话 我们可以通过http://localhost:8080/struts241/index!login.action来执行动态的方法调用。这种动态方法调用的时候method中的特殊字符都会被替换成空,但是可以通过http://localhost:8080/struts241/index.action?method:login来绕过无法传入特殊字符的限制。

Struts2 s2-032远程代码执行分析

接收到的参数会经过处理存入到ActionMapping的method属性中。DefaultActionProxyFactory将ActionMappping的method属性设置到ActionProxy中的method属性(虽然做了escapeEcmaScript,escapehtml4过滤,但是我们可以通过变量传递方式绕过,具体可以参考poc)。如下图

Struts2 s2-032远程代码执行分析

而DefaultActionInvocation.java中会把ActionProxy中的method属性取出来放入到ognlUtil.getValue(methodName + “()”, getStack().getContext(), action);方法中执行ognl表达式,如下图

Struts2 s2-032远程代码执行分析

3. 沙盒绕过

通过ognl表达式静态调用获取ognl.OgnlContext的DEFAULT_MEMBER_ACCESS属性,并将获取的结果覆盖_memberAccess属性,这样就可以绕过SecurityMemberAccess的限制。

4. poc

a. 测试环境

Struts2 s2-032远程代码执行分析

b. 结果


修复方案

升级至struts 2.3.20.2,struts 2.3.24.2, struts 2.3.28.1

* 参原文,转载请注明来自FreeBuf黑客与极客(FreeBuf.COM)


以上是关于Struts2 s2-032远程代码执行分析的主要内容,如果未能解决你的问题,请参考以下文章

Struts2 历史 RCE 漏洞回顾不完全系列

重磅 | Struts2 S2-048远程代码执行漏洞分析报告

漏洞分析Struts2 S2-052(CVE-2017-9805)远程代码执行漏洞分析

struts2 s2-062 ONGL远程代码执行

Struts(S2-048)远程命令执行漏洞分析

威胁预警Apache Struts2远程代码执行漏洞(S2-053)