Spring Framework RCE CVE-2022-22965漏洞学习

一、概述

3月底Spring Framework爆出严重级别的安全漏洞,该漏洞允许黑客进行任意命令执行。在3月31日Spring Framework官方发布了5.3.18以及5.2.20修复了该漏洞,随后该漏洞编号为CVE-2022-22965,这个漏洞也是先发布修复版本,后分配CVE编号的。从官网可知该漏洞存在的条件:

  • 使用JDK9及以上版本
  • 使用Apache Tomcat作为容器
  • 使用了传统的WAR包部署方式
  • 依赖了spring-wemvc以及springwebflux
  • Spring Framework版本为5.3.0到5.3.17,5.2.0到5.2.19以及其他老版本

这些条件需要同时满足,漏洞才会存在。

目前网上已经很多的文章进行漏洞分析,并且已经存在大量的POC/EXP,这篇文章就主要讲一下如何搭建漏洞环境进行漏洞验证。

声明:文章仅用于记录漏洞的学习过程,严禁用于任何非法行为,一切恶意破坏行为与本人无关。

二、环境准备

1、 编码工具,我使用的是IDEA;

2、 springframework:5.3.17,以及spring-beans

3、 JDK:电脑安装了JDK8、JDK9、JDK10、JDK17不同的版本

4、 TOMCAT:我准备了8.0.47、9.0.60、10.0.8

5、 操作系统:windows 10、linux CentOS Linux release

7.4.1708 (Core)

不知道是我的电脑环境有问题还是什么原因,在windows上怎么也复现不了漏洞,最后我代码是在windows 10+IDEA+JDK9上编写,测试可以成功启动后,再打包为war包,到linux+ TOMCAT9.0.60+ JDK9上进行复现的。

三、代码及打包

1、 在IDEA中新建项目:我命名为springFrameworkdemo03,选择JDK11,如下:

2、 选择spring WEB,Spring Boot还是2.6.6,如下:

3、 在pom.xml文件中增加spring-beans信息,使用有漏洞的5.3.17版本,默认是5.3.18:

<dependency>

    <groupId>org.springframework</groupId>

    <artifactId>spring-beans</artifactId>

    <version>5.3.17</version>

</dependency>

更新一下pom.xml文件,然后看看External Libraries中已经更新了5.3.17:

4、 编写Controller文件,文件名:IndexController

package com.example.springframeworkdemo03;



import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;



@RestController

public class IndexController {



    @RequestMapping("/unnamed/index2")

    public void index(EvalBean evalBean,int id,String name){

        System.out.println("id: " + id);

        System.out.println("str: " + name);

        System.out.println(evalBean);

        evalBean.setName(name);

    }

    @RequestMapping("/")

    public void root(EvalBean evalBean){

        System.out.println(evalBean);

    }

}

5、 编写参数绑定的实现文件,就是一堆的getter以及setter方法,EvalBean文件如下:

package com.example.springframeworkdemo03;



public class EvalBean {

    public EvalBean(){

        System.out.println("调用了evalbean.evalbean");

    }

    public String name;

    public CommonBean commonBean;



    public String getName() {

        System.out.println("调用了evalbean.getName");

        return name;

    }



    public void setName(String name) {

        System.out.println("调用了evalbean.setName");

        this.name = name;

        System.out.println("evalbean中的this.name:"+this.name);

    }



    public CommonBean getCommonBean() {

        System.out.println("调用了evalbean.getCommonBean");

        return commonBean;

    }



    public void setCommonBean(CommonBean commonBean) {

        System.out.println("调用了evalbean.setCommonBean");

        this.commonBean = commonBean;

    }

}

CommonBean文件:

package com.example.springframeworkdemo03;



public class CommonBean {

    public String common;



    public String getCommon() {

        return common;

    }



    public void setCommon(String common) {

        this.common = common;

    }

}

6、 看一下我的目录结构:

7、 配置项目的构建,原来的名字太长了,都删掉,然后起一个springfwd03:

8、 配置IDEA的tomcat:

选择前一步的包名称springfwd03:

9、 启动Tomcat测试一下Spring是否可以正常的启动:

可以看到在日志中显示Spring已经正常启动,这里我遇到很多的问题,报JAVA版本错误、或者tomcat启动了,日志中也显示部署了war包,但是spring没有正常运行等等。通过浏览器访问:

查看日志:

再带参数访问:http://localhost:8080/unnamed/index2?name=abc&id=12,然后查看一下日志:

10、经过前面几步,可以看到这个环境已经正常了,现在把打包好的war包文件取出来,名称为springfwd03.war,路径为:IdeaProjects\springFrameworkdemo03\out\artifacts\springfwd03。也可以在Buid下面去手工打包。

四、部署到linux环境

1、 linux IP地址为192.168.238.142,这里我使用的是openJDK11:

2、 部署后访问,并且查看日志:

五、利用

1、在GITHUB上搜索CVE-2022-22965,有很多的POC/EXP可以下载学习,从GITHUB上下载了一个大佬的EXP:

在webapps/ROOT目录下已经生成了tomcatwar.jsp,如下:

2、浏览器访问:​ ​http://192.168.238.142:8080/tomcatwar.jsp?pwd=j&cmd=cat%20/etc/passwd​ ​,结果如下:

PS:在IDEA中后来检查的时候发现jsp文件也上传成功了的,就是利用访问的时候不成功,路径在:

C:\Users\user1\AppData\Local\JetBrains\IntelliJIdea2021.3\tomcat\d01a009d-ce38-4468-a34b-4b47c13486a5\webapps\ROOT

六、修复措施

1、 在3月31日SpringFramework官网已经发布了修复版本5.3.18以及5.2.20,因此比较彻底的解决方式为升级SpringFramework版本解决;

2、 由于该漏洞仅在JDK9及以上才可以被利用,因此可以降低JDK版本至JDK8;

3、 升级Tomcat的版本,从官网可以看到Apache Tomcat已经发布了10.0.20、9.0.62以及8.5.78版本,从Tomcat方面阻断该漏洞的利用链;

4、 利用WAF、IPS等应用层的入侵检测设备,可以看到公开的EXP都是通过POST上传了jsp文件,而在参数中都带有class、classloader等字段,因此可以对这些字段进行过滤。

七、检测措施

1、 通过测试及各方资料可以看到,当漏洞被利用后,access_log文件日志没有再产生新的访问日志,因此该文件会有访问日志缺失;

2、 在日志缺失之前会有访问上传的jsp文件的日志,可以看一下是否有异常的jsp文件访问;

3、 可以看一下在webapps相关的目录下是否有异常的jsp文件生成,如webapps/ROOT/tomcatwar.jsp,webapps/ROOT/shell.jsp文件等;

4、 这是绿盟提供的JSP脚本检测工具,不过我没有测试,有兴趣的可以去测试一下:https://zhuanlan.zhihu.com/p/491123557

八、总结

本篇文章重点在记录如何搭建Spring Framework RCE漏洞CVE-2022-22965环境,关于漏洞的成因由于个人知识有限,这里没有讲解,请见参考资料。

九、参考资料

1、 SpringFramework官网说明:https://spring.io/blog/2022/03/31/spring-framework-rce-early-announcement

2、 GITHUB大佬的文章,包含原理讲解:​ ​https://github.com/TheGejr/SpringShell​ ​

3、 B站大佬关于原理的讲解:https://www.bilibili.com/video/BV1ei4y1Q7nm?from=search&seid=6034420883713438739&spm_id_from=333.337.0.0

4、 在VULFOCUS上也已经更新了靶机,可以自行更新靶机或者登录开放的这个平台上直接去测试:http://vulfocus.io/#/login

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据引用\[1\]和引用\[2\]的信息,CVE-2022-22947漏洞Spring Cloud Gateway中的一处命令注入漏洞。攻击者可以通过利用此漏洞执行SpEL表达式,从而在目标服务器上执行任意恶意代码,获取系统权限。具体来说,当使用Spring Cloud Gateway的应用程序对外暴露了Gateway Actuator接口时,攻击者可以发送恶意请求,利用漏洞进行代码注入攻击,从而在远程主机上执行任意远程代码。这个漏洞的影响范围包括Spring Cloud Gateway 3.1.x < 3.1.1和Spring Cloud Gateway 3.0.x < 3.0.7版本,以及其他旧的、不受支持的Spring Cloud Gateway版本。\[1\]\[2\] #### 引用[.reference_title] - *1* *2* [Spring Cloud Gateway RCE漏洞原理分析与复现(CVE-2022-22947)](https://blog.csdn.net/qq_49619863/article/details/127350543)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [CVE-2022-22947 Spring Cloud Gateway 远程代码执行漏洞复现](https://blog.csdn.net/weixin_45260839/article/details/124650584)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值