总结:独立的pom 引入,统一管理版本号;
    注意:import scope只能用在dependencyManagement里面

    想必大家在做SpringBoot应用的时候,都会有如下代码:

    1. <parent>
    2. <groupId>org.springframework.boot</groupId>
    3. <artifactId>spring-boot-starter-parent</artifactId>
    4. <version>1.3.3.RELEASE</version>
    5. </parent>

    继承一个父模块,然后再引入相应的依赖

    假如说,我不想继承,或者我想继承多个,怎么做?

    Maven的继承和Java的继承一样,是无法实现多重继承的,如果10个、20个甚至更多模块继承自同一个模块
    那么按照我们之前的做法,这个父模块的dependencyManagement会包含大量的依赖。
    如果你想把这些依赖分类以更清晰的管理,那就不可能了
    import scope依赖能解决这个问题。
    你可以把dependencyManagement放到单独的专门用来管理依赖的pom中,
    然后在需要使用依赖的模块中通过import scope依赖,就可以引入dependencyManagement。
    例如可以写这样一个用于依赖管理的pom:
    [

    ](https://blog.csdn.net/mn960mn/article/details/50894022)

    1. <project>
    2. <modelVersion>4.0.0</modelVersion>
    3. <groupId>com.test.sample</groupId>
    4. <artifactId>base-parent1</artifactId>
    5. <packaging>pom</packaging>
    6. <version>1.0.0-SNAPSHOT</version>
    7. <dependencyManagement>
    8. <dependencies>
    9. <dependency>
    10. <groupId>junit</groupId>
    11. <artifactid>junit</artifactId>
    12. <version>4.8.2</version>
    13. </dependency>
    14. <dependency>
    15. <groupId>log4j</groupId>
    16. <artifactid>log4j</artifactId>
    17. <version>1.2.16</version>
    18. </dependency>
    19. </dependencies>
    20. </dependencyManagement>
    21. </project>

    然后我就可以通过非继承的方式来引入这段依赖管理配置

    1. <dependencyManagement>
    2. <dependencies>
    3. <dependency>
    4. <groupId>com.test.sample</groupId>
    5. <artifactid>base-parent1</artifactId>
    6. <version>1.0.0-SNAPSHOT</version>
    7. <type>pom</type>
    8. <scope>import</scope>
    9. </dependency>
    10. </dependencies>
    11. </dependencyManagement>
    12. <dependency>
    13. <groupId>junit</groupId>
    14. <artifactid>junit</artifactId>
    15. </dependency>
    16. <dependency>
    17. <groupId>log4j</groupId>
    18. <artifactid>log4j</artifactId>
    19. </dependency>

    注意:import scope只能用在dependencyManagement里面

    这样,父模块的pom就会非常干净,由专门的packaging为pom来管理依赖,也契合的面向对象设计中的单一职责原则。此外,我们还能够创建多个这样的依赖管理pom,以更细化的方式管理依赖。这种做法与面向对象设计中使用组合而非继承也有点相似的味道。

    那么,如何用这个方法来解决SpringBoot的那个继承问题呢?

    1. <dependencyManagement>
    2. <dependencies>
    3. <dependency>
    4. <groupId>org.springframework.boot</groupId>
    5. <artifactId>spring-boot-dependencies</artifactId>
    6. <version>1.3.3.RELEASE</version>
    7. <type>pom</type>
    8. <scope>import</scope>
    9. </dependency>
    10. </dependencies>
    11. </dependencyManagement>
    12. <dependencies>
    13. <dependency>
    14. <groupId>org.springframework.boot</groupId>
    15. <artifactId>spring-boot-starter-web</artifactId>
    16. </dependency>
    17. </dependencies>

    这样配置的话,自己的项目里面就不需要继承SpringBoot的module了,而可以继承自己项目的module了。