`
schy_hqh
  • 浏览: 555959 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

Maven的依赖-硬依赖,传递依赖,依赖排除(NEW)

 
阅读更多
 依赖的查询
 
 
 硬依赖
指的就是必须由本模块来引入的依赖
传递依赖
当引入其它模块时,由于其它模块中已经有了某些jar包的依赖了,将自动把依赖关系导入到本模块
如,A模块已经配置了对hibernate的依赖,
当B模块中引入A模块的依赖时,hibernate的依赖将自动传入到B模块中。
此时,B模块中不用再配置hibernate的依赖了,会根据传递过来的依赖自动导入那些jar包!
依赖排除
由于有了传递性依赖的特征,当不想导入当前所引入的模块的依赖时,可以使用排除策略,将对应的依赖排除掉。
 
==================================================================
 
 
 
 硬依赖
user-core模块
该模块用于定义实体类,需要的依赖的jar包:hibernate, mysql-connector, log4j, junit 
依赖包的说明:
mysql-connector用来使用Java连接Mysql数据库
hibernate用来持久化对象
junit用来做单元测试
log4j用来做日志
依赖包的坐标通过上面的网址进行查询即可
则POM.xml配置如下:
<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.gc.user</groupId>
  <artifactId>user-core</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>user-core</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>
	
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.10</version>
      <scope>test</scope>
    </dependency>
    
    <dependency>
		<groupId>org.hibernate</groupId>
		<artifactId>hibernate-core</artifactId>
		<version>4.2.6.Final</version>
	</dependency>
	
   <dependency>
		<groupId>mysql</groupId>
		<artifactId>mysql-connector-java</artifactId>
		<version>5.1.26</version>
	</dependency>
    
    <dependency>
		<groupId>log4j</groupId>
		<artifactId>log4j</artifactId>
		<version>1.2.16</version>
	</dependency>
                           
  </dependencies>
</project>
 
 ==================================================================
 
 
 
  传递依赖
user-dao模块
 本模块主要功能是对对象进行持久化操作,当然就离不开hibernate的支持。
由于该模块需要使用到user-core模块中的实体,那么就需要引入user-core模块
那么,user-core模块就需要进行发布(deploy),当发布到私服上,本地就可以下载到该模块的jar包了
注意:
user-core模块中已经依赖了hibernate的jar包,当user-dao模块引入user-core模块时,
user-dao模块就不需要在pom.xml中配置对hibernate的依赖了,因为依赖会传递!
当然,由于user-core模块中对mysql-connector, log4j都有依赖,那么本模块也会自动引入它们!
注意:
依赖传递需要明确的两点:
1.依赖是否传递由scope来决定
2.传递的是依赖关系,而不是将jar包从A模块拷贝到B模块
由于Junit的scope定义为了test,所以该依赖关系不会传递到另一个模块中,
所以,本模块中如果要使用Junit,那么还需要配置对Junit的依赖!
 
本模块中的pom.xml
<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.gc.user</groupId>
  <artifactId>user-dao</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>user-dao</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.10</version>
      <scope>test</scope>
    </dependency>
    
     <!-- 引入user-core,将会发生传递性依赖:user-core中的依赖是否会导入到本模块中,还要根据scope决定! -->  	<dependency>
  		<groupId>com.gc.user</groupId>
  		<artifactId>user-core</artifactId>
  		<version>0.0.1-SNAPSHOT</version>
  	</dependency>
  </dependencies>
</project>
 
 
依赖的scope属性
决定该依赖是否传递,是否被打入war包
scope=compile,默认范围,该范围的依赖传递最强,编译,打包,运行都需要;
scope=test,依赖不会传递,生成war包时不会导入;测试包不需要传递,也不需要打入到war包。
scope=provided,依赖不会传递,生成war包时不会导入。仅编译,测试时有用,与test范围有点类似,但是出发点不一样。如servlet-api,容器已经提供了,就不能再包含了,否则,会导致包冲突等异常发生。
scope=runtime,编译时没有依赖,运行时有依赖
scope=system,导入本地jar包,通过指定本地路径来导入
scope=import
 
依赖传递的冲突
本模块依赖其它几个模块,而这几个模块中对某个jar包的依赖版本不同,那么本模块将使用哪个依赖呢?
Maven将自动根据"最短路径原则"来确定!
最短路径原则:
如果本地显示依赖了某个jar包,则用本地的;
如果本地没有显示依赖,而是通过依赖传递依赖的某个jar包:
首先根据最短依赖原则确定;
如果路径长度都相同,则根据依赖书写顺序确定;
依赖的排除 
Maven基于最短路径原则,解决了依赖冲突的问题,我们还可以通过依赖排除来进一步干涉依赖的传递行为。
如,引入user-core时,我不想使用user-core关于log4j的依赖,那么在引入user-core的时候,声明需要排除的依赖即可:
    <!-- 引入user-core,将会发生传递性依赖:user-core中的依赖是否会导入到本模块中,还要根据scope决定! -->
  	<dependency>
  		<groupId>com.gc.user</groupId>
  		<artifactId>user-core</artifactId>
  		<version>0.0.1-SNAPSHOT</version>
  		<exclusions>
	  		<!-- 排除user-core模块中关于log4j的依赖 -->
  			<exclusion>
  				<groupId>log4j</groupId>
  				<artifactId>log4j</artifactId>
  			</exclusion>
  		</exclusions>
  	</dependency>
 
 依赖的显示声明,精确控制依赖的版本
基于Maven的最短路径原则解决了多个相同依赖冲突的问题
依赖排除又提供了一种依赖冲突的解决方案
此外,我们还可以直接在本模块中声明对某个jar包的依赖,优先级最高,冲突也就自动解决了
 
 
================================================================== 
 
 
 
分享到:
评论
2 楼 schy_hqh 2013-11-06  
小哥你好,我有大半年没接触Struts2开发了,具体情况不了解。
我认为有2种途径可以解决:
1.IDE提供了依赖树,不知道你用的是什么IDE,它可以看jar包是由哪个依赖导致引入的;
2.删除pom中引入的依赖,比如声明的与struts2相关的依赖,删掉一个后,maven后立即更新reference,如果junit-plugin消失了,那就是刚删的那个依赖导致的。
1 楼 mojinchuan 2013-11-06  
现在我的工程里打war包出现了这个包:struts2-junit-plugin-2.1.8.1.1.jar,但是pom.xml没有直接配置,请问我怎么知道是哪个模块的传递依赖

相关推荐

    Maven+nexus+svn+jenkins.docx

    然后,将Maven项目上传至trunk目录,注意排除不需要提交的文件(如target目录、Eclipse配置文件等)。在本地安装Subversion客户端,并确保其bin目录添加到PATH环境变量中。通过命令行使用SVN命令进行代码的提交、...

    引用第三方库的方法_安卓源码.zip

    `implementation`是依赖类型,意味着这个库只在应用运行时使用,不会被传递到其他依赖你的库。 2. **Maven Central仓库**: 大多数流行的开源Android库都会发布到Maven Central仓库。当我们写入依赖时,Gradle会...

    java开发解压文件

    通常,它会包含如何添加上述Maven依赖的步骤,以及可能的额外配置,如自定义版本或排除某些传递性依赖。 总的来说,Zip4j是一个非常实用的Java库,其易用性和强大的功能使得在Java开发中处理ZIP文件变得简单。通过...

    Spring Boot Socket实现与html页面的连接,案例讲解客户端与服务器端相互发消息.docx

    - `spring-boot-starter-test`:测试相关的依赖,但排除了`junit-vintage-engine`,可能是为了避免与JUnit5的冲突。 2. **WebSocket配置**: 在Spring Boot应用中,我们需要创建一个WebSocket配置类,启用...

    频道管理封装5步实现

    3. **排除冲突**:在`build.gradle`文件中排除冲突的依赖部分。 例如,如果你确定某个依赖包中的`gson`不是你需要的版本,可以这样排除它: ```gradle dependencies { compile ('com.example:some-library:1.0.0'...

    Android应用源码之引用第三方库的方法-IT计算机-毕业设计.zip

    这会排除指定库在传递性依赖中的版本。 然后,理解版本控制。在Android开发中,经常需要更新第三方库以获取最新功能和修复。Gradle允许你使用`+`号来指定最新版本,或者使用`~&gt;`操作符指定最小版本并自动获取小版本...

    Struts2-JSON-Example

    这个插件通常包含在Struts2的核心库中,如果没有,可以单独下载或在Maven或Gradle的依赖配置中添加。 在Struts2的配置文件(struts.xml或struts-default.xml)中,我们需要开启JSON支持。可以通过以下配置实现: `...

    lombok.jar及eclipse两种安装方式

    - 对于使用Maven或Gradle的项目,还需要在构建配置中添加Lombok的依赖。 以上就是关于Lombok在Eclipse或MyEclipse中的安装与使用方法,以及对`lombok.jar`的介绍。通过Lombok,开发者可以更专注于业务逻辑,减少...

    jsoup获取网页正文

    要获取或修改元素属性,可以直接通过点操作符实现,如`element.attr("href")`获取`href`属性,`element.attr("href", "new-url")`设置`href`属性。 7. **遍历和操作元素** `Element`类提供了丰富的遍历和操作方法...

    struts2返回json

    这通常意味着在Maven的pom.xml文件或构建脚本中添加相关的依赖。 2. **配置Action**:在你的Action类中,你需要定义一个方法来处理请求并返回JSON响应。这个方法应该有`@Action`注解,并设置`resultType`为`json`。...

Global site tag (gtag.js) - Google Analytics