Spring Boot因CVE-2023-20883从2.3升级到2.7.18的过程

升级背景

因Spring Boot2.3.12存在CVE-2023-20883
安全漏洞,故决定对项目的Spring Boot版本进行升级来解决该问题。

而该漏洞在 Spring Boot 版本 3.0.0 - 3.0.6、2.7.0 - 2.7.11、2.6.0 - 2.6.14、2.5.0 - 2.5.14 和更早的不受支持的版本中,如果 Spring MVC 与反向代理缓存一起使用,则可能会发生拒绝服务 (DoS) 攻击。

升级注意事项

  1. 确定版本号
  2. 确定依赖的传递方式

本次升级我确定升级为2.7.18版本,且因依赖的传递方式决定从tree的根部节点开始升级,另一种方式可以考虑在子项目进行排除覆盖直接升级。

升级过程

  1. 修改pom中Spring Boot的版本号
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.18</version>
        <relativePath />
    </parent>
  1. 刷新pom进行编译后发现mysql依赖报错,在Spring Boot2.7.8开始,mysql链接包进行了移动,修改mysql依赖为第二个方式
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>com.mysql</groupId>
            <artifactId>mysql-connector-j</artifactId>
            <scope>runtime</scope>
        </dependency>
  1. 修改pom文件中读取本地lib的方式
    在这里插入图片描述
  2. 修改pom文件中finalName的设置格式
    在这里插入图片描述

遇到的问题

在项目编译和启动阶段遇到的问题

  1. 如果在项目中自定义了错误处理,实现了ErrorController.getErrorPath方法,在2.5.3后Spring Boot不再支持该方法,需要修改处理逻辑代码。
package org.springframework.boot.web.servlet.error;

public interface ErrorController {
}
  1. junit版本不兼容问题,如果在项目中使用junit4或者更早版本junit3,则需要修改依赖关系,因为在2.7.18中支持最低junit版本是junit5
    在这里插入图片描述
  2. 在项目启动过程中出现循环依赖问题,因为在2.6以后Spring Boot默认不允许bean的循环引用,故增加配置允许循环引用,当然还有别的处理方式,请自行查询循环依赖和其他方式
spring.main.allow-circular-references:true
  1. 在项目中如果有进行对request路由进行过滤处理的逻辑,需要注意RequestMappingInfo.getPatternsCondition().getPatterns()已经不适用了,很容易在获取RequestCondition报空指针异常,那么在2.7.18中还有一个方法getPathPatternsCondition()也可以获取到路由,如果是想获取RequestCondition对象那么还有getActivePatternsCondition()进行获取,这个问题是在2.6.0以前和以后策略不同所造成的。当然还有其他方式可以简单解决。
    增加配置将策略改回2.6前的方式,该配置在springboot3.X中部分版本还适用
spring:
  mvc:
    pathmatch:
      matching-strategy: ant_path_matcher
  1. 在项目启动时出现NoClassDefFoundError报错,报错位置在启动类
    注意该报错和ClassNotFoundException是两码事
    经检查在我的项目在多项目依赖过程中,修改了<spring-framework.version>5.2.24.RELEASE</spring-framework.version>
    **原因:**可以看见我的项目是使用<parent>标签继承了spring-boot-starter-parent进行版本升级的,在spring-boot-starter-parent中我们可以看见又继承了spring-boot-dependencies,而在spring-boot-dependencies中我们可以发现
    在这里插入图片描述
    我项目中修改的版本和2.7.18兼容的最低版本相差甚远
    注释掉我声明的spring-framework后编译启动成功。
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.aleks</groupId> <artifactId>demo</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>pom</packaging> <modules> <module>deploy</module> <module>module</module> </modules> <properties> <java.version>1.8</java.version> <!-- 修改版本号 --> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> <version>2.7.18</version> <!-- 同步版本号 --> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.7.18</version> <!-- 同步版本号 --> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter</artifactId> <version>5.8.2</version> <!-- Java 8兼容版本 --> <scope>test</scope> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.29</version> </dependency> <!-- Log4j2 API --> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>2.20.0</version> </dependency> <!-- Log4j2 Core 实现 --> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>2.20.0</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.12</version> <!-- java8最新稳定版 --> <scope>provided</scope> <!-- 必须设置为provided --> </dependency> </dependencies> </dependencyManagement> </project>帮我按标准排排序 备注加一下 规范一下
最新发布
03-20
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值