maven学习笔记(二) 依赖

原创 2013年12月06日 11:15:22

maven版本:apache-maven-3.1.1  
IDE: springsource   默认支持maven集成
            若使用的是eclipse,则需要先安装m2eclipse来支持maven的集成

     注意:

     修改IDE集成的maven版本,使用自己新安装的maven  (Window->Preferences->Maven->Installations)
      若修改了默认本地仓库路径,还需要在 Window->Preferences->Maven->User Settings 中配置路径指向修改后的本地仓库下的settings.xml文件,
      本地路径为 D:\dev_env\maven\settings.xml

依赖包的查询
1、所有的依赖都是通过坐标来进行存储的(GAV-->groupId、artifactId、version),也是通过坐标来查找的
2、有一些网上的仓库提供了坐标的查询(http://mvnrepository.com),输入需要查找的jar包(如:spring,struts)

依赖传递

若项目A依赖了C jar包,B项目依赖了A项目,则B项目依赖了C jar包,这就是依赖的传递(这种依赖是基于compile范围进行传递的)

下面以一个实例来说明依赖传递的冲突和maven解决冲突的机制:

 若存在A、B、C、D四个项目,他们之间互相依赖,A依赖B和C,B依赖D

 同等长度的依赖路径-->根据依赖定义顺序处理冲突             

若B和C中都依赖了POI的jar包,B依赖poi-3.9 ,C依赖 poi-3.10,那么根据传递性A也会依赖poi,此时根据B和C在A的pom文件(A依赖B、C,会在dependencies中定义)中依赖的顺序决定poi的版本,若B在前面则A依赖poi-3.9;否则依赖poi-3.10

不同等长度的依赖路径-->根据依赖路径长度取路径短的依赖       

若C和D中都依赖了POI的jar包,C依赖poi-3.9 ,D依赖 poi-3.10,那么根据传递性A也会依赖poi,由于A到C的路径较短,所以A会依赖poi-3.9

可在依赖中排除某些依赖关系(控制依赖、也可以解决依赖冲突)

若B和C中都依赖了log4j的jar包,B依赖log4j-1.2.16 ,C依赖 log4j-1.2.17,那么根据传递性A也会依赖log4j,可在A项目的pom文件中排除B项目的log4j依赖,此时A就会依赖C的log4j-1.2.17

A项目pom文件依赖定义如下:

<dependency>
			<groupId>B</groupId>
			<artifactId>B</artifactId>
			<version>SNAPSHOT-0.0.1</version>
			<type>jar</type>
			<scope>compile</scope>
			<exclusions>
	    		<exclusion>
	    			<groupId>log4j</groupId>
	    			<artifactId>log4j</artifactId>
					<version>1.2.16</version>
	    		</exclusion>
	    	</exclusions>
		</dependency>
		<dependency>
			<groupId>C</groupId>
			<artifactId>C</artifactId>
			<version>SNAPSHOT-0.0.1</version>
			<type>jar</type>
			<scope>compile</scope>
		</dependency>

依赖范围

1、test范围指的是测试范围有效,在编译和打包时都不会使用这个依赖
2、compile范围指的是编译范围有效,在编译和打包时都会将依赖存储进去
3、provided依赖:在编译和测试的过程有效,最后生成war包时不会加入,诸如:servlet-api,因为servlet-api,tomcat等web服务器已经存在了,如果再打包会冲突
4、runtime在运行的时候依赖,在编译的时候不依赖

默认的依赖范围是compile

依赖范围对传递性依赖的影响

假设现在有一个项目A依赖项目B,项目B依赖log4j,则称A对B的依赖为第一直接依赖,B对log4j的依赖为第二直接依赖

下图中左边一列表示第一直接依赖的范围,上面的一行表示第二直接依赖的范围。

假设:A对B的依赖范围为compile(<scope>compile</scope>),B对log4j的依赖范围为compile,

           那么根据下图可查到传递性依赖的范围为compile,表示A对log4j的依赖也是compile

根据上面图例可总结:

       当第二直接依赖的范围为compile时,传递性依赖的范围与第一直接依赖的范围一致;

       当第二直接依赖的范围为test时,依赖不会传递;

       当第二直接依赖的范围为provided时,只有当第一直接依赖的范围也为provided时,依赖才会传递且传递依赖的范围也是provided;

       当第二直接依赖的范围为runtime时,传递性依赖的范围与第一直接依赖范围一致(但第一直接依赖范围为compile时比较特殊,此时传递性依赖范围为runtime)。

聚合和继承

聚合:分模块开发的各个子项目要分别编译、测试、打包会很麻烦,可以建立一个单独的项目parent,这个项目中只有一个pom文件,将分开的子项目作为模块(在pom文件中使用module配置)配置到parent项目中,运行parent中的pom文件,就能自动同时一并构建各个模块。

继承:分模块开发的各个子项目的pom文件中会有很大一部分的配置元素是重复的(如:作为一个大项目的各个模块,groupId应该是相同的;依赖的重复配置),可以建立一个单独的项目parent,这个项目的pom文件会抽取那些公有的重复配置供各个子模块继承(子项目的pom文件中使用parent配置需要继承的pom项目信息)。

继承的配置主要是:

1、在子项目的pom文件中使用parent元素对父pom进行定义

2、在父pom文件中会定义一些公共的元素供子pom继承,父pom中定义依赖是要在dependencies节点上添加一个父级节点dependencyManagement

聚合和继承的父pom文件中的packaging属性的值必须是pom

下面引用上一篇文章中提到的视频中的实例:

user-parent作为聚合项目、被继承的父项目,这个项目中只有一个pom文件;其余的都是子项目

user-parent的pom文件

<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>org.konghao.user</groupId>
  <artifactId>user-parent</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>pom</packaging>
  <modules>
  	<module>../user-core</module>
  	<module>../user-dao</module>
  	<module>../user-log</module>
  	<module>../user-service</module>
  </modules>
  <url>http://maven.apache.org</url>
  <!-- <repositories>
  	<repository>
      <id>central</id>
      <name>Central Repository</name>
      <url>https://nexus.sourcesense.com/nexus/content/repositories/public/</url>
      <layout>default</layout>
      <snapshots>
        <enabled>false</enabled>
      </snapshots>
    </repository>
  </repositories> -->
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <junit.version>4.10</junit.version>
  </properties>
  <dependencyManagement>
  	<dependencies>
	  	<dependency>
	  		<groupId>junit</groupId>
	  		<artifactId>junit</artifactId>
	  		<version>${junit.version}</version>
	  		<scope>test</scope>
	  	</dependency>
	    <dependency>
	    	<groupId>org.konghao.user</groupId>
	    	<artifactId>user-core</artifactId>
	    	<version>0.0.1-SNAPSHOT</version>
	    </dependency>
	    <dependency>
	    	<groupId>org.konghao.user</groupId>
	    	<artifactId>user-dao</artifactId>
	    	<version>0.0.1-SNAPSHOT</version>
	    	<type>jar</type>
	    	<scope>compile</scope>
	    </dependency>
	    <dependency>
	    	<groupId>org.konghao.user</groupId>
	    	<artifactId>user-log</artifactId>
	    	<version>0.0.1-SNAPSHOT</version>
	    	<type>jar</type>
	    	<scope>compile</scope>
	    	<exclusions>
	    		<exclusion>
	    			<groupId>log4j</groupId>
	    			<artifactId>log4j</artifactId>
	    		</exclusion>
	    	</exclusions>
    	</dependency>
	     <dependency>
			<groupId>org.hibernate</groupId>
			<artifactId>hibernate-core</artifactId>
			<version>3.6.10.Final</version>
		</dependency>
		<dependency>
			<groupId>log4j</groupId>
			<artifactId>log4j</artifactId>
			<version>1.2.16</version>
		</dependency>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.18</version>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>slf4j-log4j12</artifactId>
			<version>1.6.4</version>
		</dependency>
		<dependency>
			<groupId>javassist</groupId>
			<artifactId>javassist</artifactId>
			<version>3.12.1.GA</version>
		</dependency>
		<dependency>
			<groupId>commons-logging</groupId>
			<artifactId>commons-logging</artifactId>
			<version>1.1.1</version>
		</dependency>
  	</dependencies>
  </dependencyManagement>
</project>


user-core的pom文件

<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>
  <parent>
  	<groupId>org.konghao.user</groupId>
  	<artifactId>user-parent</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<relativePath>../user-parent/pom.xml</relativePath>
  </parent>
  <artifactId>user-core</artifactId>
  <name>user-core</name>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
    </dependency>
   <dependency>
		<groupId>org.hibernate</groupId>
		<artifactId>hibernate-core</artifactId>
	</dependency>
	<dependency>
		<groupId>log4j</groupId>
		<artifactId>log4j</artifactId>
	</dependency>
	<dependency>
		<groupId>mysql</groupId>
		<artifactId>mysql-connector-java</artifactId>
	</dependency>
	<dependency>
		<groupId>org.slf4j</groupId>
		<artifactId>slf4j-log4j12</artifactId>
	</dependency>
	<dependency>
		<groupId>javassist</groupId>
		<artifactId>javassist</artifactId>
	</dependency>
  </dependencies>
</project>


其余子项目的pom文件类似与user-core

依赖分析

可在项目的根路径下运行maven命令,分析当前项目的依赖情况

mvn dependency:list  显示已解析依赖

mvn dependency:tree   依赖树

mvn dependency:analyze  依赖分析      需要关注Used undeclared dependencies found(项目中使用到的,但没有直接声明的,传递性依赖过来的),需要显示声明这些依赖

                    

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Maven常见异常及解决方法

异常1: [ERROR] Failed to execute goal on project biz_zhuhai: Could not resolve dependencies for proje...
  • lch_cn
  • lch_cn
  • 2012年11月26日 13:38
  • 123825

Maven使用总结(二):Maven依赖配置

Maven依赖配置这一篇来聊一聊Maven的依赖配置。

maven详解之坐标与依赖

maven坐标和依赖详解, maven依赖的调优技术 maven依赖配置的最佳实践 maven配置的常见问题的解决方案...

maven学习笔记(四)仓库、nexus私服

构件:在maven中,任何一个依赖(jar包)、插件(maven-compiler-plugin-2.5.1.jar)或者项目输出(前面例子中运行mvn clean install部署到本地仓库的ja...

jsoup的基础理论(一)

一、   JSOUP简介 在以往用java来处理解析HTML文档或者片段时,我们通常会采用htmlparser(http://htmlparser.sourceforge.net/)这个开源类库。现...
  • xh16319
  • xh16319
  • 2014年06月02日 20:54
  • 5080

Maven学习笔记(三)——坐标和依赖

参考书籍Maven实战:可在InfoQ的Minibook出下载相关电子版。 一、坐标 maven坐标为各种构件引入了秩序,任何一个构件都必须明确定义自己的坐标,而一组maven坐标...

Maven学习笔记(十)坐标与依赖

坐标与依赖 Maven的一大功能是管理项目依赖,为了能自动化解析任何一个java构件,Maven就必须将它们唯一标识,这就依赖管理的底层基础——坐标! 何为Maven坐标 Maven定义了...

Maven学习笔记2-坐标与依赖

Maven坐标Maven定义了这样一组规则,世界上任何一个构件都可以使用Maven坐标唯一标识,Maven坐标的元素包括groupId、artifactId、version、packaging、cla...

Maven学习笔记之坐标和依赖

Maven中的坐标和依赖是最基本的基础。

Maven学习笔记(2) --- 依赖

maven依赖在maven项目中,我们会在pom.xml文件中引入我们需要用到的依赖,一般用groupId,artifactId,version就够了,如下: org.springframew...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:maven学习笔记(二) 依赖
举报原因:
原因补充:

(最多只允许输入30个字)