《转》maven中import scope依赖方式解决单继承问题的理解

来源:互联网 发布:一朝成名天下知猜生肖 编辑:程序博客网 时间:2024/05/20 09:07

转载:https://www.cnblogs.com/huahua035/p/7680607.html

在maven多模块项目中,为了保持模块间依赖的统一,常规做法是在parent model中,使用dependencyManagement预定义所有模块需要用到的dependency(依赖)

<dependencyManagement>        <dependencies>            <!-- Feign是一种声明式、模板化的HTTP客户端:以HTTP接口的形式暴露自身服务 -->            <dependency>                <groupId>org.springframework.cloud</groupId>                <artifactId>spring-cloud-starter-feign</artifactId>                <version>${spring-cloud-starter-feign.version}</version>            </dependency>            <!-- 支持面向方面的编程即AOP,包括spring-aop和AspectJ -->            <dependency>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-starter-aop</artifactId>                <version>${spring.boot.version}</version>            </dependency>            <dependency>                <groupId>org.aspectj</groupId>                <artifactId>aspectjrt</artifactId>                <version>${aspectjrt.version}</version>            </dependency>        </dependencies>    </dependencyManagement>

然后,子model根据实际需要引入parent中预定义的依赖,

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

好处:

1、依赖统一管理(parent中定义,需要变动dependency版本,只要修改一处即可);

2、代码简洁(子model只需要指定groupId、artifactId即可)

3、dependencyManagement只会影响现有依赖的配置,但不会引入依赖,即子model不会继承parent中dependencyManagement所有预定义的depandency,只引入需要的依赖即可,简单说就是“按需引入依赖”或者“按需继承”;因此,在parent中严禁直接使用depandencys预定义依赖,坏处是子model会自动继承depandencys中所有预定义依赖;

但是,问题也出现了:

单继承:maven的继承跟java一样,单继承,也就是说子model中只能出现一个parent标签;

parent模块中,dependencyManagement中预定义太多的依赖,造成pom文件过长,而且很乱;

如何让这些依赖可以分类并清晰的管理?

问题解决:import scope依赖

如何使用:

1、maven2.9以上版本

2、将dependency分类,每一类建立单独的pom文件

3、在需要使用到这些依赖的子model中,使用dependencyManagement管理依赖,并import scope依赖

3、注意:scope=import只能用在dependencyManagement里面,且仅用于type=pom的dependency

 <dependencyManagement>        <dependencies>            <dependency>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-dependencies</artifactId>                <!-- 重要:版本号要和父模块中预定义的spring boot版本号保持一致 -->                <version>${spring.boot.version}</version>                <type>pom</type>                <scope>import</scope>            </dependency>        </dependencies>    </dependencyManagement>

个人总结

看了几篇文章,看了这个之后总算知道了这个是什么意思。

1.一般多模块管理依赖都是在父pom.xml声明dependencyManagement,然后子模块显示依赖(无需版本)

dependencyManagement: 专门为了管理模块依赖,不会被直接传递到子模块,需要显示依赖。
父pom.xml不应该定义dependencies,除非是所有模块都需要的,因为这个会直接传递给子模块

2.但是如果我们还需要引用其他系统的一些模块,写很多个dependency显然太low,如果能直接引用这个系统的父pom.xml就好了

但是maven是单继承,因此子模块不能再继承其他系统的parent pom.xml了.
于是就有了scope:import

》只能在dependencyManagement
》type只能是pom.xml(即父pom.xml)
》是声明在parent pom.xml的dependencyManagement,提供给子模块引用的

作用就相当于把其他系统的父pom.xml的子模块全部引入进来了,
并且子模块在用的时候可以只需要依赖该系统的一部分模块
(例如import spring-parent.pom, 子模块可以只依赖spring-web)

原创粉丝点击