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

Spring Boot 与 Maven 依赖管理详解

目录

  • 前言
  • 一、Maven 依赖管理
    • 1.1 dependencies
      • 作用
    • 1.2 dependencyManagement(推荐)
      • 作用
      • 注意
    • 1.3 两者区别
  • 二、多模块项目最佳实践
    • 2.1 推荐结构
    • 2.2 统一管理版本
    • 2.3 公共依赖
    • 2.4 企业项目推荐模式
  • 三、Spring Boot 版本与 JDK 对照表
    • JDK8 推荐版本
    • JDK17 推荐版本
    • 常见组合
      • 老项目
      • 新项目
  • 四、Spring Boot Starter 机制
    • 4.1 什么是 Starter
    • 4.2 Starter 的真正价值
  • 五、spring-boot-starter-parent
    • 5.1 是什么
    • 5.2 作用
      • 统一管理版本
      • 管理插件版本
      • 提供默认配置
    • 5.3 注意
  • 六、spring-boot-starter
    • 6.1 是什么
    • 6.2 引入内容
    • 6.3 不包含
  • 七、spring-boot-starter-web
    • 7.1 是什么
    • 7.2 依赖结构
    • 7.3 可以直接使用
  • 八、spring-boot-starter-test
    • 8.1 为什么需要
    • 8.2 包含内容
    • 8.3 常见测试
      • SpringBootTest
      • Mockito
    • 8.4 scope=test
  • 九、必须使用 starter-parent 吗?
    • 方式1(推荐)
    • 方式2(企业项目常见)
  • 十、三者关系图
  • 九、Spring Boot 项目标准依赖模板
  • 十、总结
    • Maven
    • Spring Boot
    • 推荐组合
      • JDK8
      • JDK17+
      • 多模块项目

前言

在日常 Java 开发中,我们几乎都会接触到 Maven 和 Spring Boot。

很多初学者会有以下疑问:

  • dependenciesdependencyManagement有什么区别?
  • Maven 多模块项目如何管理依赖?
  • Spring Boot 为什么只引入一个 Starter 就能使用很多功能?
  • spring-boot-starter-parentspring-boot-starterspring-boot-starter-web有什么区别?
  • 单元测试为什么还要引入spring-boot-starter-test
  • Spring Boot 各版本支持哪些 JDK?

本文将系统梳理这些知识点。


一、Maven 依赖管理

1.1 dependencies

作用

用于真正引入依赖

例如:

父工程:

<project><packaging>pom</packaging><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.42</version></dependency></dependencies></project>

子模块:

<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency>

这种情况下:

  • 子模块会自动继承该依赖
  • 实际上子模块甚至不用再写这段 dependency
  • Maven 会自动传递给所有子模块

可以执行:

mvn dependency:tree

查看依赖树验证。


1.2 dependencyManagement(推荐)

作用

用于:

统一管理依赖版本

例如:

<project><packaging>pom</packaging><dependencyManagement><dependencies><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>shardingsphere-jdbc</artifactId><version>5.5.2</version></dependency></dependencies></dependencyManagement></project>

子模块:

<dependency><groupId>org.apache.shardingsphere</groupId><artifactId>shardingsphere-jdbc</artifactId></dependency>

无需再写:

<version>5.5.2</version>

这种情况下:

  • 子模块必须声明 dependency
  • 不需要写 version
  • Maven 会从父工程的dependencyManagement中找到版本号

注意

dependencyManagement

不会自动引入依赖。

例如:

<dependencyManagement><dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-j</artifactId><version>9.3.0</version></dependency></dependencies></dependencyManagement>

子模块如果不写:

<dependency><groupId>mysql</groupId><artifactId>mysql-connector-j</artifactId></dependency>

是无法使用 MySQL 驱动的。


1.3 两者区别

项目dependenciesdependencyManagement
是否引入依赖
是否管理版本
子模块自动拥有
企业项目推荐公共依赖统一版本

二、多模块项目最佳实践

2.1 推荐结构

root-parent │ ├── user-service ├── order-service ├── pay-service └── common

父工程:

<project><packaging>pom</packaging></project>

2.2 统一管理版本

<dependencyManagement><dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-j</artifactId><version>9.3.0</version></dependency><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>shardingsphere-jdbc</artifactId><version>5.5.2</version></dependency></dependencies></dependencyManagement>

2.3 公共依赖

<dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies>

所有模块自动继承。


2.4 企业项目推荐模式

dependencyManagement ↓ 统一版本 dependencies ↓ 公共依赖 子模块 dependencies ↓ 按需引入

三、Spring Boot 版本与 JDK 对照表

Spring BootSpring Framework最低 JDK
1.x4.xJava 7
2.0~2.75.xJava 8
3.x6.xJava 17
4.x7.xJava 17

JDK8 推荐版本

Spring Boot 2.7.18

这是 Spring Boot 2.x 最后一个正式版本。


JDK17 推荐版本

Spring Boot 3.x

常见组合

老项目

JDK8 Spring Boot 2.7.18 MyBatis MySQL Redis

新项目

JDK17 Spring Boot 3.x Spring Cloud 2025+

四、Spring Boot Starter 机制

4.1 什么是 Starter

Starter 本质上是:

依赖聚合包

作用:

一次性引入一组兼容的依赖

例如:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>

实际上会引入:

spring-web spring-webmvc tomcat jackson validation spring-boot spring-boot-autoconfigure

4.2 Starter 的真正价值

Starter ≠ 自动配置

实际上:

Starter + AutoConfiguration = 开箱即用

例如:

spring:redis:host:localhost

然后:

@AutowiredprivateRedisTemplateredisTemplate;

直接可用。

原因:

Redis Starter ↓ RedisAutoConfiguration ↓ 自动创建 Bean

五、spring-boot-starter-parent

5.1 是什么

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.18</version></parent>

它是:

Maven 父工程

5.2 作用

统一管理版本

例如:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>

无需指定版本。


管理插件版本

例如:

maven-compiler-plugin maven-surefire-plugin spring-boot-maven-plugin

提供默认配置

例如:

UTF-8 Java版本 资源过滤

5.3 注意

它:

不提供 Spring Boot 功能

只是管理 Maven 配置。


六、spring-boot-starter

6.1 是什么

Spring Boot 核心启动器。

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency>

6.2 引入内容

spring-core spring-context spring-beans spring-aop spring-boot spring-boot-autoconfigure logging

6.3 不包含

spring-web spring-webmvc tomcat

因此:

@RestController

无法使用。


七、spring-boot-starter-web

注意:正确名称是spring-boot-starter-web,不是spring-boot-web


7.1 是什么

Spring Boot Web 开发启动器。

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>

7.2 依赖结构

spring-boot-starter-web │ ├── spring-boot-starter ├── spring-web ├── spring-webmvc ├── jackson ├── validation └── tomcat

注意:

spring-boot-starter-web 已经包含 spring-boot-starter

所以,对于 web 项目:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>

即可,spring-boot-starter会被自动引入,无需再手动引入。


7.3 可以直接使用

@RestController@RequestMapping@GetMapping@PostMapping

八、spring-boot-starter-test

8.1 为什么需要

Web Starter 不包含测试框架。

如果要进行单元测试,需要引入:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency>

8.2 包含内容

JUnit5 Mockito AssertJ Hamcrest Spring Test JSONassert

8.3 常见测试

SpringBootTest

@SpringBootTestclassUserServiceTest{@AutowiredprivateUserServiceuserService;@Testvoidtest(){}}

Mockito

@ExtendWith(MockitoExtension.class)classUserServiceTest{@MockprivateUserMapperuserMapper;@InjectMocksprivateUserServiceuserService;}

8.4 scope=test

<scope>test</scope>

表示:

阶段可用
main编译
test编译
test运行
打包Jar

因此测试框架不会进入生产环境。


九、必须使用 starter-parent 吗?

不是必须,Spring Boot 官方支持两种方式。

方式1(推荐)

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.18</version></parent>

然后:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>

不用写版本。

这是最简单的方式。

方式2(企业项目常见)

很多公司已经有自己的父工程:

<parent><groupId>com.company</groupId><artifactId>company-parent</artifactId></parent>

这时候不能再继承:

spring-boot-starter-parent

因为Maven只能有一个parent。

于是改成:

<dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.7.18</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement>

效果和 starter-parent 几乎一样。


十、三者关系图

spring-boot-starter-parent │ ├── 管理版本 ├── 管理插件 └── 不提供功能 spring-boot-starter │ ├── spring-core ├── spring-context ├── spring-boot └── logging spring-boot-starter-web │ ├── spring-boot-starter ├── spring-web ├── spring-webmvc ├── jackson └── tomcat

九、Spring Boot 项目标准依赖模板

对于 JDK8 + Spring Boot 2.7.18 项目:

<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.18</version></parent><dependencies><!-- Web开发 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- Lombok --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><!-- redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><!-- 单元测试 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies>

十、总结

Maven

dependencies ↓ 真正引入依赖 dependencyManagement ↓ 统一管理版本

Spring Boot

spring-boot-starter-parent ↓ 管理版本和插件 spring-boot-starter ↓ Boot核心功能 spring-boot-starter-web ↓ Web开发 spring-boot-starter-test ↓ 单元测试

推荐组合

JDK8

Spring Boot 2.7.18

JDK17+

Spring Boot 3.x

多模块项目

父工程 ├── dependencyManagement(统一版本) ├── dependencies(公共依赖) └── modules 子模块 └── dependencies(按需引入)
http://www.cnnetsun.cn/news/2897586.html

相关文章:

  • VS2013一键编译的MFC版PE文件结构查看器源码包
  • 三秒极速恢复!用QEMU检查点快照为你的开发环境打造“时光机”(附-monitor命令详解)
  • ArcGIS栅格计算器不够用?试试用Python脚本实现‘条件批量处理’:以植被覆盖度与异常值填充为例
  • 为什么传统压缩工具无法满足现代数据管理需求?7-Zip-zstd的六种算法解决方案深度解析
  • 番茄小说下载器技术解析与多平台部署指南
  • 日冕环振荡与KHI湍流阻尼的观测与模拟研究
  • ESP32-C3单SPI驱动双屏ST7735S:在VSCode+PIO环境下修改TFT_eSPI库的完整避坑记录
  • Ubuntu部署Docker
  • 调度域和调度组
  • 编写程序录入家人过敏食材清单,搭配每日菜谱,自动规避致敏食物并提醒。
  • 3分钟掌握:高效实用的网易云音乐ncm转mp3完整指南
  • 海量SKU背后的管理黑洞:PLM如何终结配方、包材与成本的混乱状态?
  • 3个关键功能,让Snap Hutao成为你原神冒险的最佳伙伴
  • 别再让单片机直接驱动电机了!用ULN2003驱动步进电机的保姆级教程(附Arduino代码)
  • 物流全自动包装产线PLC控制系统设计23(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码
  • TCP 与 UDP:从核心区别到面试必问的可靠性机制
  • 深度解析ExplorerPatcher:3大实战技巧让你的Windows桌面效率提升50%
  • 嵌入式安全实践:基于IEC 60730标准的MCU硬件特性与软件自检设计
  • 终极NES模拟器Mesen完全指南:从怀旧游戏到专业调试的完整解决方案
  • 从‘金银岛’到背包问题:贪心算法的适用边界与实战场景分析
  • 【CANdelaStudio-从入门到深入到实战】01 开篇:为什么你写的诊断代码总被退回来?
  • Fast-GitHub浏览器插件架构解析:国内GitHub访问优化实现原理
  • DRG Save Editor:如何轻松管理你的深岩银河游戏存档?
  • 自建量化回测系统完全指南 (上):四大技术栈与主流开源框架深度对比
  • 微信数据库解密完整指南:3步掌握AES-256加密破解技术
  • 计算机毕业设计之一款在线实验报告软件的设计
  • CANdevStudio:零成本开启你的CAN总线仿真开发之旅
  • 终极透明浏览器:Glass Browser完整使用指南与最佳实践
  • PyTorch模型部署避坑指南:torch.load加载模型时,map_location参数到底该怎么设?
  • 告别资源焦虑:用Snap Hutao智能工具箱重构你的原神游戏体验