使用maven最烦人的可能就是类包之间的版本冲突引发的问题了,类包冲突的一个很大的原因即产类包之间的间接依赖引起的。每个显式声明的类包都会依赖于一些其它的隐式类包,这些隐式的类包会被maven间接引入进来,因而可能造成一个我们不想要的类包的载入,严重的甚至会引起类包之间的冲突。
要解决这个问题,首先就是要查看pom.xml显式和隐式的依赖类包,然后通过这个类包树找出我们不想要的依赖类包,手工将其排除在外就可以了。
下面,通过一个例子来说明:
我的项目使用testng进行测试,使用了untilis,由于unitils的类包会隐式依赖于junit,这是我不想看到的,下面的目的就是找出junit会谁隐式载入了,然后exculte掉它。
通过idea的maven依赖分析将不需要的依赖exclude掉
打开maven的pom.xml,在某个<dependency>中通过右键菜单:maven->show dependency 打开分析的图形化页面,如下所示:
通过菜单的exclude即解决这个间接依赖。
通过这个依赖树,我们还可以看到Junit还通过“unitils-spring”的依赖间接载入了,如下所示:
从上面的依赖树中,我们可以看出junit通过unitils-spring的unitils-database间接引入了,由于我的项目都不需要数据库的测试,因此,可以把unitils-database项整个exclude掉。
下面,是处理完成后的pom.xml关键片断:
<dependency>
<groupId>org.unitils</groupId>
<artifactId>unitils-testng</artifactId>
<version>${unitils.version}</version>
<scope>test</scope>
<exclusions>
<exclusion>
<artifactId>junit</artifactId>
<groupId>junit</groupId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.unitils</groupId>
<artifactId>unitils-spring</artifactId>
<version>${unitils.version}</version>
<scope>test</scope>
<exclusions>
<exclusion>
<artifactId>unitils-database</artifactId>
<groupId>org.unitils</groupId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
这样,被间接隐式引入的junit就被我们exclude在外了。
有时通过idea的依赖分析工具产生的树不够全,这时就需要使用mvn dependency:tree来查看依赖树了。
通过mvn dependency:tree 查看依赖树
引用
mvn dependency:tree
以下是使用这个工具产生的依赖树:
引用
E:\01workspace\chenxh\09research\rop\rop>mvn dependency:tree
[WARNING]
[WARNING] Some problems were encountered while building the effective settings
[WARNING] 'pluginRepositories.pluginRepository.id' must not be 'local', this identifier is reserved for the local re
tory, using it for other repositories will corrupt your repository metadata. @ C:\Users\Administrator\.m2\settings.x
[WARNING]
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building rop 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] --- maven-dependency-plugin:2.1:tree (default-cli) @ rop ---
[INFO] com.rop:rop:jar:1.0-SNAPSHOT
[INFO] +- javax.validation:validation-api:jar:1.0.0.GA:compile
[INFO] +- org.hibernate:hibernate-validator:jar:4.2.0.Final:compile
[INFO] +- org.codehaus.jackson:jackson-core-asl:jar:1.9.5:compile
[INFO] +- org.codehaus.jackson:jackson-mapper-asl:jar:1.9.5:compile
[INFO] +- org.codehaus.jackson:jackson-jaxrs:jar:1.9.5:compile
[INFO] +- org.codehaus.jackson:jackson-xc:jar:1.9.5:compile
[INFO] +- com.fasterxml.jackson.dataformat:jackson-dataformat-xml:jar:2.0.0-RC2:compile
[INFO] | +- com.fasterxml.jackson.core:jackson-core:jar:2.0.0-RC2:compile
[INFO] | +- com.fasterxml.jackson.core:jackson-annotations:jar:2.0.0-RC2:compile
[INFO] | +- com.fasterxml.jackson.core:jackson-databind:jar:2.0.0-RC2:compile
[INFO] | +- com.fasterxml.jackson.module:jackson-module-jaxb-annotations:jar:2.0.0-RC2:compile
[INFO] | \- org.codehaus.woodstox:stax2-api:jar:3.1.1:compile
[INFO] | \- javax.xml.stream:stax-api:jar:1.0-2:compile
[INFO] +- org.slf4j:slf4j-api:jar:1.6.1:compile
[INFO] +- org.slf4j:slf4j-log4j12:jar:1.6.1:compile
[INFO] +- log4j:log4j:jar:1.2.16:compile
[INFO] +- org.springframework:spring-core:jar:3.1.1.RELEASE:compile
[INFO] | +- org.springframework:spring-asm:jar:3.1.1.RELEASE:compile
[INFO] | \- commons-logging:commons-logging:jar:1.1.1:compile
[INFO] +- org.springframework:spring-context:jar:3.1.1.RELEASE:compile
[INFO] | +- org.springframework:spring-aop:jar:3.1.1.RELEASE:compile
[INFO] | +- org.springframework:spring-beans:jar:3.1.1.RELEASE:compile
[INFO] | \- org.springframework:spring-expression:jar:3.1.1.RELEASE:compile
[INFO] +- org.springframework:spring-context-support:jar:3.1.1.RELEASE:compile
[INFO] +- org.springframework:spring-web:jar:3.1.1.RELEASE:compile
[INFO] | \- aopalliance:aopalliance:jar:1.0:compile
[INFO] +- org.springframework:spring-test:jar:3.1.1.RELEASE:compile
[INFO] +- org.springframework:spring-webmvc:jar:3.1.1.RELEASE:compile
[INFO] +- org.testng:testng:jar:6.3:test
[INFO] | +- org.beanshell:bsh:jar:2.0b4:test
[INFO] | +- com.beust:jcommander:jar:1.12:test
[INFO] | \- org.yaml:snakeyaml:jar:1.6:test
[INFO] +- org.mockito:mockito-all:jar:1.8.5:test
[INFO] +- javax.servlet:servlet-api:jar:2.5:provided
[INFO] +- org.unitils:unitils-core:jar:3.3:test
[INFO] | +- commons-lang:commons-lang:jar:2.3:test
[INFO] | +- commons-collections:commons-collections:jar:3.2:test
[INFO] | \- ognl:ognl:jar:2.6.9:test
[INFO] +- org.unitils:unitils-testng:jar:3.3:test
[INFO] | \- org.testng:testng:jar:jdk15:5.8:test
[INFO] | \- junit:junit:jar:3.8.1:test
[INFO] \- org.unitils:unitils-spring:jar:3.3:test
[INFO] +- org.springframework:spring-tx:jar:2.5.2:test
[INFO] \- org.unitils:unitils-database:jar:3.3:test
[INFO] +- org.unitils:unitils-dbmaintainer:jar:3.3:test
[INFO] | +- org.hibernate:hibernate:jar:3.2.5.ga:test
[INFO] | | +- net.sf.ehcache:ehcache:jar:1.2.3:test
[INFO] | | +- asm:asm-attrs:jar:1.5.3:test
[INFO] | | +- dom4j:dom4j:jar:1.6.1:test
[INFO] | | +- antlr:antlr:jar:2.7.6:test
[INFO] | | +- cglib:cglib:jar:2.1_3:test
[INFO] | | \- asm:asm:jar:1.5.3:test
[INFO] | \- org.dbunit:dbunit:jar:2.2.2:test
[INFO] | +- junit-addons:junit-addons:jar:1.4:test
[INFO] | | +- xerces:xercesImpl:jar:2.6.2:test
[INFO] | | \- xerces:xmlParserAPIs:jar:2.6.2:test
[INFO] | +- poi:poi:jar:2.5.1-final-20040804:test
[INFO] | \- org.slf4j:slf4j-nop:jar:1.4.3:test
[INFO] +- commons-dbcp:commons-dbcp:jar:1.2.2:test
[INFO] | \- commons-pool:commons-pool:jar:1.3:test
[INFO] \- org.springframework:spring-jdbc:jar:2.5.2:test
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 8.250s
[INFO] Finished at: Fri Jun 08 09:08:09 CST 2012
[INFO] Final Memory: 7M/245M
[INFO] ------------------------------------------------------------------------
我原来一个使用idea分析不出的隐式依赖就是通用mvn dependency:tree找到的。
- 大小: 88.5 KB
- 大小: 65 KB
分享到:
相关推荐
总结来说,解决Maven依赖冲突需要深入理解Maven的依赖管理和类加载机制。在本案例中,通过修改冲突依赖的类路径,可以实现多版本依赖的共存,但这种方式并不适用于所有场景,因此在实际应用中应谨慎考虑。在可能的...
2. 版本兼容性:需要确保离线包中的依赖版本与项目POM.xml中声明的版本匹配,否则可能会出现版本冲突。 3. 缺少依赖:如果项目需要的某个特定版本不在离线包中,仍需网络下载。 在实际开发中,为了更好地利用Maven...
### Maven 类包冲突终极解决技巧详解 在软件开发过程中,Maven 作为一款流行的构建工具,在项目管理和构建自动化方面发挥着重要作用。然而,对于新手而言,Maven 的复杂性和广泛的功能可能会让人感到困惑,尤其是在...
对于第二类依赖冲突,同名类存在于多个不同的依赖 jar 包当中,这种情况是 Maven 无法解决的,因为 Maven 只会为你针对同一个 Jar 包的不同版本进行仲裁,而这俩是属于不同的 Jar 包,超出了 Maven 的依赖管理范畴。...
6. **依赖冲突解决**:Maven采用"最接近原则"解决依赖冲突,即当两个或更多依赖引入相同jar的不同版本时,会选择离当前模块最近的版本。 7. **聚合与继承**:聚合(aggregation)允许一个项目包含其他项目,而继承...
这在排查依赖冲突或理解项目依赖关系时非常有用。 除了Maven的默认仓库外,还可以通过`<repository>`标签添加自定义的远程仓库地址,这对于处理公司内部私有库或者第三方库的非中央仓库发布的情况非常关键。 在...
当我们在 IDEA 中创建一个新的 Maven 项目,并添加新的依赖包时,可能会遇到 JDK 版本冲突问题。这是因为 Maven 没有指定编译版本,而是使用了默认的编译版本,这可能与项目所需的 JDK 版本不同,导致冲突。 二、...
8. **依赖冲突**:其他库可能已经引入了sauronsoftware包的不同版本,导致版本冲突。使用Maven的`dependency:tree`命令查看依赖树,找出可能的冲突。 通过以上步骤,通常可以解决Maven导入依赖失败的问题。如果问题...
MavenRunHelper插件的作用是帮助用户更轻松地在InteliJ IDEA中运行maven项目,它可以自动配置Maven运行环境,并且可以自动识别 maven项目的依赖关系,从而节省时间和精力。
6. **冲突解决**:当多个jar包包含相同类时,可能会引发类冲突。在Maven中,可以通过调整依赖的`<scope>`或者使用`<exclusions>`标签来避免冲突。 7. **测试与调试**:在实际项目中,使用JSONObject进行JSON操作后...
5. **仓库**:Maven依赖的存储库,包括本地仓库(默认在用户目录下)和远程仓库(如中央仓库mvnrepository.com)。当本地仓库没有所需依赖时,Maven会尝试从远程仓库下载。 6. **排除依赖(exclude)**:有时候我们...
本插件参考58开源插件MavenManager,采用dependencyManagement方式,一键解决Java开发过程中使用maven作为依赖管理时的jar包依赖冲突问题,相比MavenHelper更加省时省力,jar包版本采用最新版本号原则
总的来说,解决Maven依赖冲突需要理解其工作原理,结合IDEA提供的工具,如Maven Helper插件和依赖结构图,可以有效地定位和排除冲突,保持项目的稳定性和可维护性。在实际开发中,避免引入不必要的依赖和定期清理...
在使用"Maven依赖包"时,开发者需要注意以下几点: 1. **正确配置POM.xml**:确保所有必需的依赖项都已添加,并且版本号正确无误。 2. **理解依赖传递性**:Maven会自动处理依赖的依赖,但可能会导致依赖冲突,需要...
本资源“maven依赖包(用于博客项目)”显然包含了一系列与博客项目相关的Maven依赖,这些依赖可能包括数据库连接库、模板引擎、日志框架、安全组件以及其他有助于构建博客平台的Java库。 1. **Maven仓库**: ...
maven依赖冲突是指项目依赖的某一个jar包,有多个不同的版本,因而造成类包版本冲突。这种情况下,项目可能会出现无法编译或运行的错误。 依赖冲突的原因: 依赖冲突很经常是类包之间的间接依赖引起的。每个显式...
构建maven工程时pom.xml中引入依赖时有红色字体,setting处理了,也将jar包的版本号都试了一遍,还是没解决,后来请教大牛,原来是没连网,maven工程加载了一部分jar包,连网之后自动下载的jar包跟之前的冲突,用这...
maven依赖冲突插件:idea依赖很多的时候 可以使用插件帮我们快速查看冲突的依赖 并快速的解决依赖
1. **依赖冲突**:当项目中的多个库引用了不同版本的同一个依赖时,可能导致冲突。解决方法是在pom.xml中明确指定依赖的版本,或者使用 `<dependencyManagement>` 标签来统一管理所有子模块的依赖版本。 2. **插件...