常见Maven误解:parent pom中的继承与dependencyManagement的误操作
最编程
2024-07-27 10:17:55
...
项目结构
maven-test-proj项目下面有2个核心模块:mvn-common、mvn-server
mvn-common 基础公共组件空间:下面有一个具体的组件 mvn-base
mvn-server 是业务空间:下面有一个具体业务 server1
使用场景1
mvn-server 父pom
<?xml version="1.0" encoding="UTF-8"?>
<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">
<parent>
<artifactId>maven-test-proj</artifactId>
<groupId>org.softeem</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>mvn-server</artifactId>
<packaging>pom</packaging>
<modules>
<module>server1</module>
</modules>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
</dependencyManagement>
</project>
server1 子pom
<?xml version="1.0" encoding="UTF-8"?>
<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">
<parent>
<artifactId>mvn-server</artifactId>
<groupId>org.softeem</groupId>
<version>1.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>server1</artifactId>
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
</dependency>
</dependencies>
</project>
子pom中使用的依赖,直接从父pom中的依赖管理 dependencyManagement 中获取,不写版本号,此时是能正常使用的,idea也不会报错属于标准写法
使用场景2
mvn-server 父pom不变;server1子pom调整如下
<?xml version="1.0" encoding="UTF-8"?>
<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">
<parent>
<artifactId>mvn-server</artifactId>
<groupId>org.softeem</groupId>
<version>1.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>server1</artifactId>
<!-- 重复父pom中的依赖管理 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
</dependencies>
</dependencyManagement>
<!-- 此时也能正常使用,无需加版本号,使用的是自己依赖管理中的库 -->
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
</dependency>
</dependencies>
</project>
此时子pom中也能正常使用,无需加版本号,使用的是自己依赖管理中的库,idea不会报错
使用场景3
将场景2中的配置稍作调整一下,移除掉依赖管理中的版本号
<?xml version="1.0" encoding="UTF-8"?>
<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">
<parent>
<artifactId>mvn-server</artifactId>
<groupId>org.softeem</groupId>
<version>1.0-SNAPSHOT</version>
<relativePath>../pom.xml</relativePath>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>server1</artifactId>
<!-- 移除掉依赖管理中的版本号 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.softeem</groupId>
<artifactId>mvn-base</artifactId>
</dependency>
</dependencies>
</project>
此时看下idea中的显示
能成功将包依赖进来,但是idea上面会显示报错,同时pom文件会显示报错,提示未知的版本号
总结
我们在使用Maven中的 dependencyManagement 进行依赖管理的时候,是不存在父子之间继承的,需要指定版本号,不要想着会从父pom中继承版本号。同时对于同一个包父子 dependencyManagement 都有定义的时候,子pom中指定的版本号会优先被使用