Maven实战(六)依赖

上一篇 / 下一篇  2016-06-15 15:45:39 / 个人分类:maven

1. 依赖配置 
   依赖可以声明如下: 
  

Xml代码  收藏代码
  1. <project>  
  2.   ...  
  3.   <dependencies>  
  4.     <dependency>  
  5.       <groupId>group-a</groupId>  
  6.       <artifactId>artifact-a</artifactId>  
  7.       <version>1.0</version>  
  8.       <exclusions>  
  9.         <exclusion>  
  10.           <groupId>group-c</groupId>  
  11.           <artifactId>excluded-artifact</artifactId>  
  12.         </exclusion>  
  13.       </exclusions>  
  14.     </dependency>  
  15.     <dependency>  
  16.       <groupId>group-a</groupId>  
  17.       <artifactId>artifact-b</artifactId>  
  18.       <version>1.0</version>  
  19.       <type>bar</type>  
  20.       <scope>runtime</scope>  
  21.     </dependency>  
  22.   </dependencies>  
  23. </project>  

 我们在Maven实战(二)中就遇到了依赖的概念,项目中测试需要依赖junit jar包,依赖配置如下:

Xml代码  收藏代码
  1. <dependencies>  
  2.     <dependency>  
  3.       <groupId>junit</groupId>  
  4.       <artifactId>junit</artifactId>  
  5.       <version>3.8.1</version>  
  6.       <scope>test</scope>  
  7.     </dependency>  
  8.  </dependencies>  

 依赖会包含基本的groupId, artifactId,version等元素,根元素project下的dependencies可以包含一个或者多个dependency元素,以声明一个或者多个依赖。
 下面详细讲解每个依赖可以包含的元素:

 

  groupId,artifactIdversion:依赖的基本坐标,对于任何一个依赖来说,基本坐标是最重要的,Maven根据坐标才能找到需要的依赖

 

  type: 依赖的类型,对应于项目坐标定义的packaging。大部分情况下,该元素不必声明,其默认值是jar

 

  scope: 依赖的范围,下面会进行详解

 

  optional: 标记依赖是否可选

 

  exclusions: 用来排除传递性依赖,下面会进行详解

 

  大部分依赖声明只包含基本坐标。


2. 依赖范围

 Maven在编译主代码的时候需要使用一套classpath,在编译和执行测试的时候会使用另一套classpath,实际运行项目的时候,又会使用一套classpath。

 依赖范围就是用来控制依赖与这三种classpath(编译classpath、测试classpath、运行classpath)的关系,Maven有以下几种依赖范围:

 

compile: 编译依赖范围。如果没有指定,就会默认使用该依赖范围。使用此依赖范围的Maven依赖,对于编译、测试、运行三种classpath都有效。

 

test: 测试依赖范围。使用此依赖范围的Maven依赖,只对于测试classpath有效,在编译主代码或者运行项目的使用时将无法使用此类依赖。典型的例子就是JUnit,它只有在编译测试代码及运行测试的时候才需要。

 

provided: 已提供依赖范围。使用此依赖范围的Maven依赖,对于编译和测试classpath有效,但在运行时无效。典型的例子是servlet-api,编译和测试项目的时候需要该依赖,但在运行项目的时候,由于容器已经提供,就不需要Maven重复地引入一遍。

 

runtime: 运行时依赖范围。使用此依赖范围的Maven依赖,对于测试和运行classpath有效,但在编译主代码时无效。典型的例子是JDBC驱动实现,项目主代码的编译只需要JDK提供的JDBC接口,只有在执行测试或者运行项目的时候才需要实现上述接口的具体JDBC驱动。

 

system: 系统依赖范围。该依赖与三种classpath的关系,和provided依赖范围完全一致。但是,使用system范围依赖时必须通过systemPath元素显式地指定依赖文件的路径。由于此类依赖不是通过Maven仓库解析的,而且往往与本机系统绑定,可能造成构建的不可移植,因此应该谨慎使用。systemPath元素可以引用环境变量,如:

Xml代码  收藏代码
  1. <dependency>  
  2.     <groupId>javax.sql</groupId>  
  3.     <artifactId>jdbc-stdext</artifactId>  
  4.     <version>2.0</version>  
  5.     <scope></scope>  
  6.     <systemPath>${java.home}/lib/rt.jar</systemPath>  
  7. </dependency>  

 

import(Maven 2.0.9及以上): 导入依赖范围。该依赖范围不会对三种classpath产生实际的影响,稍后会介绍到。

 

3. 传递性依赖

 下面我们看一个简单的项目,读者可从附件中下载源码

POM.xml配置如下:

Xml代码  收藏代码
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  2.   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">  
  3.   <modelVersion>4.0.0</modelVersion>  
  4.   
  5.   <groupId>com.mycompany.app</groupId>  
  6.   <artifactId>my-app-simple</artifactId>  
  7.   <version>0.0.1-SNAPSHOT</version>  
  8.   <packaging>jar</packaging>  
  9.   
  10.   <name>my-app-simple</name>  
  11.   <url>http://maven.apache.org</url>  
  12.   
  13.   <properties>  
  14.     <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>  
  15.   </properties>  
  16.   
  17.   <dependencies>  
  18.     <dependency>  
  19.       <groupId>junit</groupId>  
  20.       <artifactId>junit</artifactId>  
  21.       <version>3.8.1</version>  
  22.       <scope>test</scope>  
  23.     </dependency>  
  24.       
  25.      <dependency>  
  26.       <groupId>org.springframework</groupId>  
  27.       <artifactId>spring-core</artifactId>  
  28.       <version>2.5.6</version>  
  29.     </dependency>  
  30.   </dependencies>  
  31. </project>  

 我们可以看到此项目引入依赖junit和spring-core,我们可以在Maven仓库中查找spring-core构件,如图:


点击POM我们会看到该文件包含了一个commons-logging依赖:

Xml代码  收藏代码
  1. <dependency>  
  2.   <groupId>commons-logging</groupId>   
  3.   <artifactId>commons-logging</artifactId>   
  4.   <version>1.1.1</version>   
  5. </dependency>  

 
 那么该依赖会传递到当前项目中,这就是依赖的传递性,打开项目查看Maven dependencies:



 

 

4. 可选依赖

 有时候我们不想让依赖传递,那么可配置该依赖为可选依赖,将元素optional设置为true即可,例如:

TAG:

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

日历

« 2019-07-02  
 123456
78910111213
14151617181920
21222324252627
28293031   

数据统计

  • 访问量: 38662
  • 日志数: 24
  • 建立时间: 2016-05-27
  • 更新时间: 2016-07-29

RSS订阅