SpringBoot 项目不继承 parent 的实现方法
当项目需要继承自定义的 parent POM 而不能直接继承 spring-boot-starter-parent 时,可以通过以下方式实现 SpringBoot 项目的功能。
一、主要实现方式
SpringBoot 官方提供了不继承 parent 的替代方案,主要通过在 dependencyManagement 中引入 spring-boot-dependencies 来实现版本仲裁功能。
二、完整配置示例
1. 基本 POM 配置
xml
<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>
<!-- 继承自定义 parent POM -->
<parent>
<groupId>com.yourcompany</groupId>
<artifactId>your-company-parent</artifactId>
<version>1.0.0</version>
</parent>
<groupId>com.example</groupId>
<artifactId>springboot-without-parent</artifactId>
<version>1.0.0</version>
<packaging>jar</packaging>
<!-- 手动配置基础属性(原本由 spring-boot-starter-parent 提供) -->
<properties>
<java.version>1.8</java.version>
<resource.delimiter>@</resource.delimiter>
<maven.compiler.source>${java.version}</maven.compiler.source>
<maven.compiler.target>${java.version}</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring.boot.version>2.7.0</spring.boot.version>
</properties>
<!-- 引入 Spring Boot 依赖管理 -->
<dependencyManagement>
<dependencies>
<!-- Spring Boot 依赖管理,提供版本仲裁 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring.boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<!-- 项目依赖 -->
<dependencies>
<!-- Spring Boot Web 依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<!-- 不需要指定版本,由 dependencyManagement 中的 spring-boot-dependencies 控制 -->
</dependency>
<!-- Spring Boot 测试依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<!-- 配置 Maven 插件 -->
<build>
<plugins>
<!-- Spring Boot Maven 插件,用于打包可执行 JAR -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring.boot.version}</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
三、关键说明
1. 版本管理
- 当不继承
spring-boot-starter-parent时,需要在dependencyManagement中显式引入spring-boot-dependencies并使用import范围 - 这样可以获得与继承 parent 相同的版本仲裁能力,引入 starter 依赖时无需指定版本
2. 基础配置
- 需要手动配置原本由 parent 提供的基础属性:
- Java 版本
- 编译参数
- 编码格式
- 资源分隔符等
3. 插件配置
- 必须手动配置
spring-boot-maven-plugin插件以支持打包功能 - 该插件负责将应用打包成可执行的 JAR 文件
四、适用场景
- 项目需要继承自定义的 parent POM(如公司内部统一的 parent)
- 需要在多个项目间共享公司级别的 Maven 配置
- 需要自定义或覆盖 SpringBoot 默认配置
五、注意事项
- 确保
spring-boot-dependencies的版本与项目使用的 SpringBoot 版本一致 - 当需要覆盖特定依赖的版本时,可以在
properties中定义相应的版本属性 - 打包时确保正确配置了主类,可通过插件配置指定:
xml
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${spring.boot.version}</version>
<configuration>
<mainClass>com.example.Application</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
通过以上配置,即使不直接继承 spring-boot-starter-parent,也能正常使用 SpringBoot 的所有核心功能,同时满足项目继承自定义 parent 的需求。