一句话解释
项目中多个模块间公共依赖的版本号、scope的控制
业务场景
一个项目有很多模块,每个模块都会用到一些公共的依赖.这些公共的依赖若交由各个模块独自管理,若每个模块同一个依赖的版本号不一致,会造成很比问题。
打包和开发测试环境下对同一jar包不同版本号的处理可能不一致,造成运行时和测试时结果不一致项目升级时,会造成修改版本号时遍地开花的问题。
该标签通常适用于多模块环境下定义一个top module来专门管理公共依赖的情况下。
若dependencies里的dependency自己没有声明version元素,那么maven就会到depenManagement里去找有没有该artifactId和groupId进行过版本声明,若存在,则继承它,若没有则报错。你必须为dependency声明一个version,若dependencies中的dependency声明了version,则dependencyManagement中的声明无效。
1. 单一模块情况下 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>
2. 多模块情况:
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的区别:
所有声明在dependencies里的依赖都会自动引入,并默认被所有的子项目继承
dependencies即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)
dependencyManagement只是声明依赖的版本号,该依赖不会引入,因此子项目需要显示声明所需要引入的依赖,若不声明则不引入子项目声明了依赖且未声明版本号和scope,则会继承父项目的版本号和scope,否则覆盖。