maven依赖继承聚合

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了maven依赖继承聚合相关的知识,希望对你有一定的参考价值。

依赖:
  <dependency>
    <groupId>junit</groupId>
    <artifactId>junit</artifactId>
    <version>4.0</version>
    <scope>test</scope>
  </dependency>
1、依赖的范围(依赖的有效性)
  compile(默认值)
  test 比如:Junit
  provided 比如:servlet-api.jar,编译和测试时要用到servlet-api.jar,但是运行时不需要它,因为tomcat集成了servlet-api.jar

  

  maven在编译、测试、运行项目时,各自使用一套classpath

2、依赖排除
  A.jar->B.jar(A.jar依赖B.jar)
  当我们通过maven引入A.jar时,会自动引入B.jar
  A.jar(x.java,y.java,z.java)  B.jar(p.java,c.java,i.java)
  A.jar和B.jar之间依赖的本质:z.java->c.java,
  x.java和y.java跟B.jar不存在依赖关系
  如果项目有中只需要x.java,不需要 z.java,则我们没必要引入B.jar,
  可以使用依赖排除,这样maven就不会自动引入B.jar了
在pom.xml中排除jar包的依赖关系:

View Code

再次强调,在pom.xml中增加完依赖后,需要maven - update project
依赖:
  commons-fileupload.jar commons-io.jar:虽然我们实际开发时,认为二者jar必须关联,但是maven可能不这么认为。

 

3、maven整合多个项目
  多个maven项目(模块)之间如何依赖:p项目依赖->q项目
    1、把q项目 install 到本地仓库
    2、在p项目pom.xml文件中配置依赖:

      <dependencies>
        <dependency>
          <groupId>org.lanqiao.maven</groupId>
          <artifactId>HelloWorld2</artifactId>
          <version>0.0.1-SNAPSHOT</version>
        </dependency>
      </dependencies>

假设有两个项目 HelloWorld2 和 HelloWorldTime,HelloWorldTime依赖于HelloWorld2,
我们可以把HelloWorld2安装到仓库(也就是install放到仓库中,可以是本地仓库,也可以是中央仓库),
然后HelloWorldTime通过在pom.xml文件中配置对HelloWorld2的依赖关系,
HelloWorldTime就能够调用HelloWorld2中的类和方法了。
在HelloWorldTime的pom.xml文件中,配置对HelloWorld2的依赖关系如下:
  <dependencies>
    <dependency>
      <groupId>org.lanqiao.maven</groupId>
      <artifactId>HelloWorld2</artifactId>
      <version>0.0.1-SNAPSHOT</version>
    </dependency>
  </dependencies>

 

4、依赖的传递性
  A.jar->B.jar->C.jar(A.jar依赖B.jar,B.jar依赖C.jar)
  要使A.jar->C.jar(A.jar依赖C.jar)需要一个前提条件:当且仅当B.jar依赖C.jar的范围是compile
  HelloWorldTime->HelloWorld2->junit(HelloWorldTime依赖HelloWorld2,HelloWorld2依赖junit)

 

5、依赖原则:为了防止冲突
  a.路径最短优先原则
    HelloWorldTime->HelloWorld->junit4.0,
    假设HelloWorldTime传递依赖junit4.0,同时自身依赖Junit3.8,则HelloWorldTime优先依赖junit3.8
  b.路径长度相同:
    i. 在同一个pom.xml文件中有2个相同的依赖(覆盖):后面声明的依赖会覆盖前面声明的依赖(严禁在同一个pom.xml中声明2个版本不同的依赖).
      例如HelloWorldTime的pom.xml文件中配置了两个junit依赖项,先声明junit3.8版本,后声明junit3.7版本,那么junit3.7会覆盖junit3.8。
    ii.如果是不同的pom.xml中有2个相同的依赖(优先):则先声明的依赖,会覆盖后声明的依赖,
      比如:HelloWorldTime依赖 HelloWorld 和 Hello 两个项目,
      HelloWorld又依赖于 commons-io2.4.jar,commons-io2.4.jar 依赖范围是compile,
      Hello依赖于commons-io2.3.jar,commons-io2.3.jar 的依赖范围是compile,
      则在 HelloWorldTime 项目中配置依赖项 HelloWorld 和 Hello 时,HelloWorld 和 Hello 谁先声明,则优先依赖谁的
      commons-io.jar包。假设 HelloWorld 先声明,Hello 后声明,则 HelloWorldTime 依赖 HelloWorld 所依赖的commons-io2.4.jar 版本。
JDK只能识别source folder 中的源码。

 

6、统一项目的jdk:
  i、build path:删除旧版本,增加新版本
  ii、右键项目-属性-project Factors-java version 改版本(之前存在要改的版本,比如把jdk 1.7改成jdk 1.8,则电脑上必须安装了jdk 1.8)
  iii、通过maven统一jdk版本,在pom.xml文件中进行配置。
可以在pom.xml中统一jdk版本、统一编码、统一jar包的版本

 

 


7、继承
依赖传递:A->B->C(A依赖B,B依赖C)
  如果 B 是在compile范围依赖于C,则A->C(A依赖C)
继承:A->B(A继承B)
  则A可以使用B的所有依赖(而不用管B与C之间依赖范围是否compile)

只要A继承B,则A可以使用B的所有依赖,简而言之,A可以使用C,也不用关心B是否在compile范围依赖C,用继承来代替依赖传递,方便很多

假设HelloWorld2继承B,B依赖junit,则继承实现步骤:
i、建立父工程B,父工程的打包方式为pom(父工程中不编写源代码,只是在pom.xml文件中编写依赖,供子工程继承)
ii、在父工程B的pom.xml中编写依赖:
  父工程的依赖需要写在pom.xml文件的dependencyManagement中,子工程中的依赖只写在<dependencies></dependencies>和<dependency></dependency>中,不写在<dependencyManagement>中
  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.0</version>
        <scope>compile</scope>
      </dependency>
    <dependencies>
  </dependencyManagement>
iii、子工程 HelloWorld2 继承一个父工程: 1、加入父工程gav 2、子工程的pom.xml到父工程的pom.xml之间的相对路径
  <parent>
    <!--1、加入父工程gav -->
    <groupId>org.lanqiao.maven</groupId>
    <artifactId>B</artifactId>
    <version>0.0.1-SNAPSHOT</version>

    <!--2、子工程的pom.xml到父工程的pom.xml之间的相对路径-->
    <relativePath>../B/pom.xml</relativePath>
  </parent>
由于父工程和子工程之间存在继承关系,子工程可以继承父工程gav中的gv,所以可以在子工程的pom.xml文件中注释掉子工程gav中的gv,只保留子工程gav中的a。
iiii、在子工程中,需要声明:使用父工程的哪些依赖,只需要gav中的ga,不用gav中的v(version)
  假如父工程依赖了无数个jar包,而子类只需要用到这无数个jar包中的3个jar包,则可以通过下面的配置实现:
  <dependencies>
    <dependency>
      <!-- 声明:需要使用到父类的junit(只需要ga)-->
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
    </dependency>
  </dependencies>

 子工程依赖了父工程中的哪些jar包,就配置哪些jar包,没必要把父工程依赖的所有jar包都拿过来

8、maven聚合
  i、maven项目能够识别的:自身包含的、本地仓库中的
  ii、Maven2依赖maven1,则在执行时:必须先将Maven1加入到本地仓库(install),之后才能执行Maven2。
    以上前置工程maven1的install操作,可以交由“聚合”一次性搞定。比如假设Maven2依赖很多个项目,则需要把它依赖的项目都install放到本地仓库,由于需要多次install,
    这种方式很麻烦,所以我们可以使用聚合来解决该问题。
  iii、聚合的使用:
    在一个总工程中配置聚合:(聚合的配置,只能配置在(打包方式为pom)的Maven工程中)
    配置聚合,避免前置工程的install操作
    <Modules>
      <!--项目的根路径,可以不用设置顺序-->
      <module>../Maven1</module>
      <module>../Maven2</module>
    </Modules>
    配置完聚合之后,以后只要操作总工程,则会自动操作该聚合中配置过的工程。
    注意:clean命令,是删除target目录,并不是清理install存放入的本地仓库。
    当项目之间存在依赖时,如果不install到本地仓库时,只要配置好聚合,项目就直接运行也不会报告。

  iiii、聚合、继承:
    聚合:
      Maven将一个大工程拆分成若干个子工程(子模块),聚合可以将拆分的多个子工程合起来。
    继承:
      父工程->子工程,可以通过父工程,统一管理依赖的版本,子工程通过声明使用父工程的哪些依赖,只需要指定gav中的ga,不用指定gav中的v(version)

 

9、maven自动部署web工程:
  通过maven直接部署运行web项目
    a、在pom.xml文件中配置cargo插件,来帮助我们自动启动tomcate
    b、在eclipse中使用maven命令:deploy
  实际开发中,开发人员将自己的项目开发完毕以后,打成war包或者jar包交给实施人员去部署。

 

10、maven仓库网站:http://www.mvnrepository.com

以上是关于maven依赖继承聚合的主要内容,如果未能解决你的问题,请参考以下文章

maven依赖继承聚合

Maven:Maven_02:依赖管理与冲突解决及项目继承聚合

maven的依赖和聚合

02-Maven高级-分模块开发依赖传递聚合继承(SpringBoot的部分底层原理)多模块开发(环境切换)Nexus私服搭建与使用

SpringBoot+vue+实战项目之第2集

项目一众筹00_07Maven概念:继承聚合创建Maven Web动态工程(问题)_Maven_servlet-api和jsp-api包依赖