Maven 中 dependencyManagement 标签使用
一句话解释
- 项目中多个模块间公共依赖的版本号、scope的控制
业务场景
- 一个项目有很多模块,每个模块都会用到一些公共的依赖
- 这些公共的依赖若交由各个模块独自管理,若每个模块同一个依赖的版本号不一致,会给项目的整
- 打包和开发测试环境下对同一 jar 包不同版本号的处理可能不一致,造成运行时和测试时结果不一致
- 项目升级时,会造成修改版本号时遍地开花的问题
- 该标签通常适用于多模块环境下定义一个top module来专门管理公共依赖的情况下
项目中依赖包版本号判断途径
- 若 dependencies 里的 dependency 自己没有声明 version 元素,那么maven 就会 到 depenManagement 里去找有没有该 artifactId 和 groupId 进行过版本声明,若存在,则继承它,若没有则报错,你必须为dependency声明一个version**
- 若 dependencies 中的 dependency 声明了version,则 dependencyManagement 中的声明无效
单一模块情况下 pom.xml
//只是对版本号进行管理,不会实际引入jar <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework</groupId> //jar 包身份限定 <artifactId>spring-core</artifactId> <version>3.2.7</version> //版本号的声明 </dependency> </dependencies> </dependencyManagement> //会实际下载jar包 <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> //不声明version 标签,则会继承 </dependency> </dependencies>
多模块情况:
parent-module 顶层模块,son1-module 和 son2-module 并列继承 parent-module
parent-module 中 pom.xml
<properties> // 集中在properties 标签中定义所有 依赖的版本号 <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <org.eclipse.persistence.jpa.version>1.2.6</org.eclipse.persistence.jpa.version> <developer.organization>xxx</developer.organization> <javaee-api.version>1.8</javaee-api.version> </properties> <dependencyManagement> //定义公共依赖的版本号 <dependencies> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>org.eclipse.persistence.jpa</artifactId> <version>${org.eclipse.persistence.jpa.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>${javaee-api.version}</version> </dependency> </dependencies> </dependencyManagement> son-module1 中 的 pom.xml <!--继承父类--> <parent> <artifactId>parent-module</artifactId> //声明父类的身份信息 <groupId>com.ppd</groupId> <version>0.0.1-SNAPSHOT</version> <relativePath>../parent-module/pom.xml</relativePath> //声明父类的pom 文件路径 </parent> <modelVersion>4.0.0</modelVersion> <artifactId>son-module</artifactId> <packaging>ejb</packaging> <!--依赖关系--> <dependencies> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> //继承父类 </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-annotations</artifactId> //继承父类 </dependency> <dependency> <groupId>org.eclipse.persistence</groupId> <artifactId>org.eclipse.persistence.jpa</artifactId> //继承父类 <scope>provided</scope> </dependency> </dependencies>
与 dependencies 标签下 dependency 的区别
- 所有声明在d ependencies 里的依赖都会自动引入,并默认被所有的子项目继承
- dependencies 即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)
- dependencyManagement 只是声明依赖的版本号,该依赖不会实现引入,因此子项目需要显示声明所需要引入的依赖,如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项
- 子项目声明了依赖且未声明版本号和scope,则会继承父项目的版本号和scope,否则覆盖
链接:https://www.jianshu.com/p/ee15cda51d9d