欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

maven多模块项目依赖管理与依赖继承详解

程序员文章站 2022-03-06 18:27:09
目录maven多模块项目依赖管理与依赖继承1、指定父模块与默认继承2、依赖管理关于maven项目依赖继承问题只需要在父项目中加入并且把父项目已pom的形式然后在子项目中以标...

maven多模块项目依赖管理与依赖继承

1、指定父模块与默认继承

dependencies即使在子项目中不写该依赖项,那么子项目仍然会从父项目中继承该依赖项(全部继承)

maven多模块项目依赖管理与依赖继承详解

父模块的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">
    <modelversion>4.0.0</modelversion>
    <groupid>com.zhangguo.maven03</groupid>
    <artifactid>maven03</artifactid>
    <packaging>pom</packaging>
    <version>1.0-snapshot</version>
    <modules>
        <module>maven03-dao</module>
        <module>maven03-service</module>
    </modules>
    <properties>
        <junit.version>4.12</junit.version>
        <spring.version>release</spring.version>
    </properties>
        <dependencies>
            <!-- junit -->
            <!-- https://mvnrepository.com/artifact/junit/junit -->
            <dependency>
                <groupid>junit</groupid>
                <artifactid>junit</artifactid>
                <version>${junit.version}</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
</project>

子模块的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>maven03</artifactid>
        <groupid>com.zhangguo.maven03</groupid>
        <version>1.0-snapshot</version>
    </parent>
    <modelversion>4.0.0</modelversion>
    <artifactid>maven03-dao</artifactid>
    <dependencies>
        <dependency>
            <groupid>org.springframework</groupid>
            <artifactid>spring-aspects</artifactid>
            <version>${spring.version}</version>
            <!--版本是从父模块依赖过来的properties-->
        </dependency>
    </dependencies>
</project>

release表示最新的发布版本,结果如下:

maven多模块项目依赖管理与依赖继承详解

2、依赖管理

dependencymanagement里只是声明依赖,并不实现引入,因此子项目需要显式的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。

当我把父项目中的依赖放到依赖管理中的效果如下所示:

<?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">
    <modelversion>4.0.0</modelversion>
    <groupid>com.zhangguo.maven03</groupid>
    <artifactid>maven03</artifactid>
    <packaging>pom</packaging>
    <version>1.0-snapshot</version>
    <modules>
        <module>maven03-dao</module>
        <module>maven03-service</module>
    </modules>
    <properties>
        <junit.version>4.12</junit.version>
        <spring.version>release</spring.version>
    </properties>
    <!--dependencymanagement里只是声明依赖,并不实现引入,
    因此子项目需要显式的声明需要用的依赖。
    如果不在子项目中声明依赖,是不会从父项目中继承来的;
    只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,
    并且version和scope都读取自父pom;
    另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。-->
    <dependencymanagement>
        <dependencies>
            <!-- junit -->
            <!-- https://mvnrepository.com/artifact/junit/junit -->
            <dependency>
                <groupid>junit</groupid>
                <artifactid>junit</artifactid>
                <version>${junit.version}</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
    </dependencymanagement>
    
</project>

结果

maven多模块项目依赖管理与依赖继承详解

这里的父模块与子模块都并没有依赖junit了,这时的依赖只是用于管理,并没有真正依赖。

<dependencymanagement>元素既能让子模块继承到父模块的依赖配置,又能保证子模块依赖使用的灵活性。

使用<dependencymanagement>声明的依赖即不会引入依赖,也不会给他的子模块引入依赖。但这段配置是可以继承的。

在子类中,依赖配置较原来就简单了。可以在子类中只配置groupid和artifactid ,省去了version。因为完整的依赖声明已经包含在父pom中。 这样可以统一项目范围中依赖的版本,帮助降低依赖冲突的几率。如果子模块不声明依赖的使用,即使该依赖已经在父pom的dependencymanangement中声明了,也不会产生任何实际的效果。

如果想要在某个模块中使用和另一个模块中完全一样的dependencymanagement配置,除了赋值和继承外,还可以使用import范围依赖将这一配置导入。

我们要达到的目的是:父模块作版本管理不实际依赖,子模块按需依赖。

父模块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">
    <modelversion>4.0.0</modelversion>
    <groupid>com.zhangguo.maven03</groupid>
    <artifactid>maven03</artifactid>
    <packaging>pom</packaging>
    <version>1.0-snapshot</version>
    <modules>
        <module>maven03-dao</module>
        <module>maven03-service</module>
    </modules>
    
    <!--版本管理-->
    <properties>
        <junit.version>4.12</junit.version>
        <spring.version>release</spring.version>
    </properties>
    <!--依赖声明-->
    <dependencymanagement>
        <dependencies>
            <!-- junit -->
            <!-- https://mvnrepository.com/artifact/junit/junit -->
            <dependency>
                <groupid>junit</groupid>
                <artifactid>junit</artifactid>
                <version>${junit.version}</version>
                <scope>test</scope>
            </dependency>
        </dependencies>
    </dependencymanagement>
</project>

子模块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>maven03</artifactid>
        <groupid>com.zhangguo.maven03</groupid>
        <version>1.0-snapshot</version>
    </parent>
    <modelversion>4.0.0</modelversion>
    <artifactid>maven03-service</artifactid>
    <dependencies>
        <!--按需依赖,版本被父模块控制,可以自行声明,优先级更高-->
        <dependency>
            <groupid>junit</groupid>
            <artifactid>junit</artifactid>
        </dependency>
    </dependencies>
</project>

结果:

maven多模块项目依赖管理与依赖继承详解

这样做的好处:统一管理项目的版本号,确保应用的各个项目的依赖和版本一致,才能保证测试的和发布的是相同的成果,因此,在顶层pom中定义共同的依赖关系。

同时可以避免在每个使用的子项目中都声明一个版本号,这样想升级或者切换到另一个版本时,只需要在父类容器里更新,不需要任何一个子项目的修改;如果某个子项目需要另外一个版本号时,只需要在dependencies中声明一个版本号即可。子类就会使用子类声明的版本号,不继承于父类版本号。

关于maven项目依赖继承问题

在maven中,子项目是可以继承父项目的依赖的。

只需要在父项目中加入

<modules>
   <module>childa</module>
   <module>childb</module>
</modules>

并且把父项目已pom的形式

打包到maven库中 (*部分必须要有)

<modelversion>4.0.0</modelversion>  
<groupid>com.sang.main</groupid>              *
<artifactid>parent-moduel</artifactid>         *
<version>1.0.2</version>            *
<packaging>pom</packaging>  
<name>simple-main</name>

然后在子项目中以<parent>标签

继承父项目即可。

<parent>
   <groupid>com.sang.main</groupid>
   <artifactid>parent-moduel</artifactid>
   <version>1.0.2</version>
</parent>

如果是父项目中的直接依赖,在子项目中什么都不用写,就会自动继承;

如果是父项目中<dependencymanagement>标签下的依赖,可以有选择性的继承,这个时候要自己在子项目添加依赖,需要有<groupid>和<artifactid>,但是版本就可以省略,直接继承父项目。 这样一来,我们就可以只继承父项目中我们需要的,而不是一股脑全部继承。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。