美文网首页
Maven 中 dependencies 与 dependenc

Maven 中 dependencies 与 dependenc

作者: 杰哥长得帅 | 来源:发表于2018-06-13 20:06 被阅读186次

    为了项目的正确运行,必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的结果

    dependencyManagement

    在项目的 parent 层,可以通过 dependencyManagement 元素来管理 jar 包的版本,让子项目中引用一个依赖而不用显示的列出版本号

    父模块中的 pom.xml

    <properties>
        <version.framework>1.0-SNAPSHOT</version.framework>
        <javaee-api.version>1.0-SNAPSHOT</javaee-api.version>
    </properties>
    <dependencyManagement>
        <dependencies>
          <dependency>
            <groupId>com.xiaojiejie</groupId>
            <artifactId>framework-cache</artifactId>
            <version>${version.framework}</version>
          </dependency>
          <dependency>  
            <groupId>javax</groupId>  
            <artifactId>javaee-api</artifactId>  
            <version>${javaee-api.version}</version>  
          </dependency>  
        </dependencies>
    </dependencyManagement>
    

    子模块中的 pom.xml

    <parent>  
        <artifactId>parent</artifactId>  
        <groupId>com.xiaojiejie</groupId>
        <version>0.0.1-SNAPSHOT</version>  
        <relativePath>../parent/pom.xml</relativePath> 
    </parent>
    <!--依赖关系-->  
    <dependencies>  
        <dependency>  
            <groupId>javax</groupId>  
            <artifactId>javaee-api</artifactId>  
        </dependency>  
        <dependency>
            <groupId>com.xiaojiejie</groupId>
            <artifactId>framework-cache</artifactId>
        </dependency>
        <dependency>  
            <groupId>com.fasterxml.jackson.core</groupId>  
            <artifactId>jackson-annotations</artifactId>  
        </dependency>  
    </dependencies>
    

    这样做的好处:统一管理项目的版本号,确保应用的各个项目的依赖和版本一致,才能保证测试的和发布的是相同的成果,因此,在顶层 pom 中定义共同的依赖关系。同时可以避免在每个使用的子项目中都声明一个版本号,这样想升级或者切换到另一个版本时,只需要在父类容器里更新,不需要任何一个子项目的修改;如果某个子项目需要另外一个版本号时,只需要在 dependencies 中声明一个版本号即可。子类就会使用子类声明的版本号,不继承于父类版本号

    dependencyManagement 的一个应用

    Maven 的继承和 Java 的继承一样,是无法实现多重继承的,如果多模块继承自同一个模块,那么按照之前的做法,这个父模块的 dependencyManagement 会包含大量的依赖。如果想把这些依赖分类以更清晰的管理,那就不可能了,import scope 依赖能解决这个问题。可以把 dependencyManagement 放到单独的专门用来管理依赖的 POM 中,然后在需要使用依赖的模块中通过 import scope 依赖,就可以引入 dependencyManagement。例如可以写这样一个用于依赖管理的 POM:

    <project>
      <modelVersion>4.0.0</modelVersion>
      <groupId>com.xiaojiejie.sample</groupId>
      <artifactId>sample-dependency-infrastructure</artifactId>
      <packaging>pom</packaging>
      <version>1.0-SNAPSHOT</version>
      <dependencyManagement>
        <dependencies>
            <dependency>
              <groupId>junit</groupId>
              <artifactid>junit</artifactId>
              <version>4.8.2</version>
              <scope>test</scope>
            </dependency>
            <dependency>
              <groupId>log4j</groupId>
              <artifactid>log4j</artifactId>
              <version>1.2.16</version>
            </dependency>
        </dependencies>
      </dependencyManagement>
    </project>
    

    然后就可以通过非继承的方式来引入这段依赖管理配置:

    <dependencyManagement>
        <dependencies>
            <dependency>
              <groupId>com.xiaojiejie.sample</groupId>
              <artifactid>sample-dependency-infrastructure</artifactId>
              <version>1.0-SNAPSHOT</version>
              <type>pom</type>
              <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
      <dependency>
        <groupId>junit</groupId>
        <artifactid>junit</artifactId>
      </dependency>
      <dependency>
        <groupId>log4j</groupId>
        <artifactid>log4j</artifactId>
      </dependency>
    

    这样,父模块的 POM 就会非常干净,由专门的 packaging 来管理依赖,也契合的面向对象设计中的单一职责原则。此外,我们还能够创建多个这样的依赖管理 POM,以更细化的方式管理依赖。这种做法与面向对象设计中使用组合而非继承也有点相似的味道

    dependencies

    相对于 dependencyManagement,所有声明在父项目中 dependencies 里的依赖都会被子项目自动引入,并默认被所有的子项目继承

    区别

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

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

    dependencyManagement 在父项目中也只是管理,并没有实际引入,所以要在 dependencies 中声明,这时也不用指明 version,比如下面的 lombok

    <?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.xiaojiejie</groupId>
        <artifactId>extension-point-api</artifactId>
        <version>1.0</version>
        <packaging>jar</packaging>
        <name>Extension Point Api</name>
    
        <properties>
            <java.version>1.8</java.version>
            <lombok.version>1.16.18</lombok.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.projectlombok</groupId>
                <artifactId>lombok</artifactId>
            </dependency>
        </dependencies>
    
        <dependencyManagement>
            <dependencies>
                <dependency>
                    <groupId>org.projectlombok</groupId>
                    <artifactId>lombok</artifactId>
                    <version>${lombok.version}</version>
                </dependency>
            </dependencies>
        </dependencyManagement>
    </project>
    

    相关文章

      网友评论

          本文标题:Maven 中 dependencies 与 dependenc

          本文链接:https://www.haomeiwen.com/subject/tnlseftx.html