从 Spring Boot 2 升级到 Spring Boot 3 的终极指南

一、升级前的核心准备

1. JDK 版本升级

Spring Boot 3 强制要求 Java 17 及以上版本。若当前项目使用 Java 8 或 11,需按以下步骤操作:

  • 安装 JDK 17:从 Oracle 或 OpenJDK 官网下载,配置环境变量(如 JAVA_HOME)。
  • IDE 设置:在 IntelliJ IDEA 或 Eclipse 中修改项目 JDK 版本(示例):
    <!-- Maven 配置示例 -->
    <properties>
        <java.version>17</java.version>
    </properties>

2. 依赖版本检查

Spring Boot 3 基于 Spring Framework 6 和 Jakarta EE 10,需确保所有依赖兼容:

  • Spring Cloud:建议升级至 2023.0.x 版本。
  • 数据库驱动:如 MyBatis 需升级到 3.0.3+,Hibernate 到 6.1.4+。
  • 第三方库:检查 Redis、ShardingSphere 等是否支持 Spring Boot 3(如 ShardingSphere 5.4.1+)。

二、代码迁移的核心步骤

1. Spring Boot 版本升级

修改 pom.xmlbuild.gradle

<!-- Maven 示例 -->
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>3.2.4</version>  <!-- 最新稳定版 -->
</parent>

2. Jakarta EE 包名替换

所有 javax.* 包需替换为 jakarta.*,例如:

// 修改前
import javax.servlet.http.HttpServletRequest;
// 修改后
import jakarta.servlet.http.HttpServletRequest;

操作技巧:使用 IDE 的全局替换功能(如 IntelliJ 的 Ctrl+Shift+R)批量修改。

3. 配置属性迁移

Spring Boot 3 中部分配置项已变更:

  • Redis 配置spring.redisspring.data.redis
  • 日志格式:默认日期格式改为 ISO-8601,可通过以下配置恢复旧格式:
    logging:
      pattern:
        dateformat: "yyyy-MM-dd HH:mm:ss.SSS"

辅助工具:添加 spring-boot-properties-migrator 生成迁移报告:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-properties-migrator</artifactId>
    <scope>runtime</scope>
</dependency>

4. 注解与 API 调整

  • @ConstructorBinding:不再需要类级别的注解,仅用于多构造函数的场景。
  • URL 匹配规则:默认关闭尾部斜杠匹配,需手动启用:
    @Configuration
    public class WebConfig implements WebMvcConfigurer {
        @Override
        public void configurePathMatch(PathMatchConfigurer configurer) {
            configurer.setUseTrailingSlashMatch(true);  // 启用斜杠匹配
        }
    }






扫描下方二维码,关注公众号:程序进阶之路,实时获取更多优质文章推送。


扫码关注

评论