当前位置: 首页 > ds >正文

Spring Boot 3为何强制要求Java 17?

简单直接的回答是:因为你选择的官方服务器 https://start.spring.io 对应的是 Spring Boot 的最新主要版本(3.x),而 Spring Boot 3.0 及更高版本强制要求最低使用 Java 17。

下面我为你详细解释原因和解决方案。

原因详解

  1. Spring Boot 3.0 的重大更新

    • 在 2022 年 11 月发布的 Spring Boot 3.0 是一个重大版本升级。它是 基于 Java 17 构建的,并且要求最低运行环境为 Java 17。这意味着你无法在 Java 11 或更早版本上运行 Spring Boot 3.0 应用。
    • 官方服务器 https://start.spring.io 默认提供的是最新的稳定版 Spring Boot。因此,当你访问它时,它生成的项目默认会兼容最新的技术栈,即 Java 17+。
  2. Jakarta EE 的转变

    • Spring Boot 3.0 的另一个巨大变化是从传统的 Java EE 迁移到了 Jakarta EE(例如,javax.persistence 包名变成了 jakarta.persistence)。
    • 这个转变始于 Java EE 的所有权从 Oracle 转移到 Eclipse 基金会。Jakarta EE 9 及更高版本要求使用新的 jakarta.* 命名空间,而这个命名空间与 Java 11 及以下的兼容性存在断裂。Spring Boot 3.0 拥抱了这一变化,因此也必须要求 Java 17 作为起跑线。
  3. 官方推荐与支持

    • Java 17 是继 Java 8 和 11 之后的又一个长期支持(LTS)版本,带来了大量性能提升和新特性。
    • Spring 团队和广大社区都强烈推荐在新项目中使用最新的 LTS 版本(目前是 Java 17 或 21),以获得更好的性能、安全性和语言特性支持。官方起始页自然也会推动这一最佳实践。

解决方案:如何创建基于 Java 11 的 Spring Boot 项目

虽然官方默认不支持,但你仍然有办法创建基于 Java 11 的项目,前提是你必须使用 Spring Boot 2.x 的最后一个版本

方法一:在 IDEA 中修改服务器 URL(推荐且简单)

Spring Initializr 有一个专门为旧版 Spring Boot 2.x 提供服务的镜像服务器。

  1. 在 IDEA 的创建项目界面,找到 Server URL 输入框。

  2. 将默认的 https://start.spring.io 替换为:

    https://start.spring.io/legacy
    

    这个 legacy 链接是 Spring 官方维护的,专门用于生成 Spring Boot 2.x 项目。

  3. 点击回车或刷新旁边的齿轮图标。

  4. 现在你会发现,Spring Boot 版本的选项变成了 2.7.x 等旧版本,并且 Java 版本的下拉菜单中出现了 118 等选项。

这是最快捷、最可靠的方法。

方法二:在官方页面手动选择旧版本

即使不更换 URL,你也可以在官方页面上手动降级配置:

  1. 保持 Server URL 为 https://start.spring.io
  2. Spring Boot 版本选择中,不要选择默认的 3.x.x 版本。点击下拉菜单,选择一个以 2.7.x 结尾的版本(例如 2.7.18),这是 Spring Boot 2.x 的最后一个特性分支版本,仍然提供支持和维护。
  3. 选择了 Spring Boot 2.x 版本后,下方的 Java 版本选择就会自动解锁 118 的选项。
方法三:创建后手动修改(备用方案)

如果你已经用默认设置创建了项目,也可以手动修改:

  1. 打开项目根目录下的 pom.xml(Maven)或 build.gradle(Gradle)文件。
  2. 修改 Java 版本
    • Maven:
      <properties><java.version>11</java.version> <!-- 将17改为11 --><maven.compiler.source>11</maven.compiler.source><maven.compiler.target>11</maven.compiler.target>
      </properties>
      
    • Gradle (在 build.gradle 中):
      sourceCompatibility = '11'
      targetCompatibility = '11'
      
  3. 降级 Spring Boot 版本(关键步骤):
    • <parent> 标签或 plugin 中的版本从 3.x.x 改为 2.7.18
    • 注意:仅仅修改 Java 版本是不够的,因为 Spring Boot 3.x 的依赖包(如 jakarta.persistence)与 Java 11 不兼容。你必须同时将 Spring Boot 版本降级到 2.x

总结

现象原因解决方案
start.spring.io 只能选 Java 17该网址默认提供最新的 Spring Boot 3.x,而 3.x 强制要求 JDK 17+1. (推荐) 更换 Server URL 为 https://start.spring.io/legacy
2. 手动选择 Spring Boot 2.7.x 版本
3. 创建后手动修改配置和版本

对于新项目,如果条件允许,强烈建议直接上手 Java 17 + Spring Boot 3.x,这是未来的趋势,也能让你享受到最新的技术和性能优化。

如果你的项目因为某些原因(如公司环境限制、老旧系统兼容)必须使用 Java 11,那么请放心地使用上述方法创建基于 Spring Boot 2.7.x 的项目,它依然是一个非常稳定且被广泛支持的版本。

http://www.xdnf.cn/news/18727.html

相关文章:

  • JavaScript 性能优化实战技术文章大纲
  • Games 101 第四讲 Transformation Cont(视图变换和投影变换)
  • 深入剖析结构体内存对齐
  • 边缘计算服务器EMI滤波器 故障分析与解决思路
  • 【LeetCode 热题 100】300. 最长递增子序列——(解法一)记忆化搜索
  • C++ 20: Concepts 与Requires
  • 链表-23.合并K个升序链表-力扣(LeetCode)
  • Qt从qmake迁移到cmake的记录
  • Spring Boot 整合网易163邮箱发送邮件实现找回密码功能
  • PHP - 线程安全 - 疑问与答案
  • PyQt6 进阶篇:构建现代化、功能强大的桌面应用
  • uniApp对接实人认证
  • Clustering Enabled Wireless Channel Modeling Using Big Data Algorithms
  • 【前端debug调试】
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘arviz’问题
  • 网站速度慢?安全防护弱?EdgeOne免费套餐一次性解决两大痛点
  • chapter05_从spring.xml读取Bean
  • 完整实验命令解析:从集群搭建到负载均衡配置
  • Java:类及方法常见规约
  • Unity中删除不及时的问题
  • 牛客面经2 京东社招-002
  • PyTorch框架之图像识别模型与训练策略
  • 25.深入对象
  • 寻找AI——高保真还原设计图生成App页面
  • 华为/思科/H3C/锐捷操作系统操作指南
  • 鸿蒙应用网络开发实战:HTTP、WebSocket、文件下载与网络检测全攻略
  • 微信小程序和uni-app面试问题总结
  • 网络模型深度解析:CNI、Pod通信与NetworkPolicy
  • Spring Boot 实时广播消息
  • Java集合(Collection、Map、转换)