SpringBoot 项目不继承 parent 的实现方法

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 文件

四、适用场景

  1. 项目需要继承自定义的 parent POM(如公司内部统一的 parent)
  2. 需要在多个项目间共享公司级别的 Maven 配置
  3. 需要自定义或覆盖 SpringBoot 默认配置

五、注意事项

  1. 确保 spring-boot-dependencies 的版本与项目使用的 SpringBoot 版本一致
  2. 当需要覆盖特定依赖的版本时,可以在 properties 中定义相应的版本属性
  3. 打包时确保正确配置了主类,可通过插件配置指定:
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 的需求。

相关推荐
哈里谢顿1 分钟前
redis的分布式设计
后端·面试
花千树-0103 分钟前
从业务接口到 MCP Tool:多语言工程化实践指南(Python / TypeScript / Java)
java·python·rpc·typescript·api·mcp
IT_陈寒9 分钟前
Java的HashMap竟然不是线程安全的?刚在生产环境踩了坑
前端·人工智能·后端
qcx2316 分钟前
深度解析Deepseek V4:1M 上下文不是军备竞赛,是养 Agent 的人才知道的痛
java·开发语言
小则又沐风a18 分钟前
基础的开发工具(2)---Linux
java·linux·前端
字节高级特工19 分钟前
MySQL数据库基础与实战指南
数据库·c++·人工智能·后端·mysql·adb
晨非辰21 分钟前
吃透C++两大默认成员函数:const成员函数、 & 取地址运算符重载
java·大数据·开发语言·c++·人工智能·后端·面试
梵得儿SHI26 分钟前
(第三篇)Spring AI 架构设计与优化:容器化与云原生部署,基于 K8s 的 AI 应用全生命周期管理
java·ci/cd·docker·云原生·kubernetes·容器化·spring ai
普修罗双战士27 分钟前
项目设计-文章系统发布文章完整前后端设计
java·数据库·vue.js·spring boot·git·intellij-idea
鹏程十八少29 分钟前
11. 2026金三银四 能答对这 29 道题,你的 Android 插件化就算真正通关了
前端·后端·面试