欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

常见Maven误解:parent pom中的继承与dependencyManagement的误操作

最编程 2024-07-27 10:17:55
...

项目结构

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pV7bFhYe-1617882532027)(C:\Users\机械革命、\AppData\Roaming\Typora\typora-user-images\image-20210408190755094.png)]

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中的显示

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Auw7szXn-1617882532031)(C:\Users\机械革命、\AppData\Roaming\Typora\typora-user-images\image-20210408192107867.png)]

能成功将包依赖进来,但是idea上面会显示报错,同时pom文件会显示报错,提示未知的版本号

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-J6QYNUN1-1617882532032)(C:\Users\机械革命、\AppData\Roaming\Typora\typora-user-images\image-20210408192228841.png)]

总结

我们在使用Maven中的 dependencyManagement 进行依赖管理的时候,是不存在父子之间继承的,需要指定版本号,不要想着会从父pom中继承版本号。同时对于同一个包父子 dependencyManagement 都有定义的时候,子pom中指定的版本号会优先被使用