使用Maven Helper解决Maven依赖冲突
Posted 花伤情犹在
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Maven Helper解决Maven依赖冲突相关的知识,希望对你有一定的参考价值。
1、何为依赖冲突
Maven是个很好用的依赖管理工具,但是再好的东西也不是完美的。Maven的依赖机制会导致Jar包的冲突。举个例子,现在你的项目中,使用了两个Jar包,分别是A和B。现在A需要依赖另一个Jar包C,B也需要依赖C。但是A依赖的C的版本是1.0,B依赖的C的版本是2.0。这时候,Maven会将这1.0的C和2.0的C都下载到你的项目中,这样你的项目中就存在了不同版本的C,这时Maven会依据依赖路径最短优先原则,来决定使用哪个版本的Jar包,而另一个无用的Jar包则未被使用,这就是所谓的依赖冲突。
在大多数时候,依赖冲突可能并不会对系统造成什么异常,因为Maven始终选择了一个Jar包来使用。但是,不排除在某些特定条件下,会出现类似找不到类的异常,所以,只要存在依赖冲突,在我看来,最好还是解决掉,不要给系统留下隐患。
造成jar包冲突的原因主要有两种
- 第一种是一个项目,依赖了同一个项目的两个版本。
- 第二种冲突原因是不同项目中,出现了相同的类。何为相同的类,即类的全限定名相同。
2、解决方法
解决依赖冲突的方法,就是使用Maven提供的标签,标签需要放在标签内部,就像下面这样:
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.10.0</version>
<exclusions>
<exclusion>
<artifactId>log4j-api</artifactId>
<groupId>org.apache.logging.log4j</groupId>
</exclusion>
</exclusions>
</dependency>
log4j-core本身是依赖了log4j-api的,但是因为一些其他的模块也依赖了log4j-api,并且两个log4j-api版本不同,所以我们使用标签排除掉log4j-core所依赖的log4j-api,这样Maven就不会下载log4j-core所依赖的log4j-api了,也就保证了我们的项目中只有一个版本的log4j-api。
3、Maven Helper
看到这里,你可能会有一个疑问。如何才能知道自己的项目中哪些依赖的Jar包冲突了呢?Maven Helper这个InteliJ IDEA的插件帮我们解决了这个问题。插件的安装方法我就不讲了,既然你都会Maven了,我相信你也是会安装插件的。
在插件安装好之后,我们打开pom.xml文件,在底部会多出一个Dependency Analyzer选项
面板说明
可以看到jsr305依赖了同一个项目的两个版本即3.0.2和3.0.1
右键说明
跳转到所在树形列表依赖
跳转到源代码
自动排除冲突依赖
冲突依赖原本没有排除冲突依赖
点击排除
效果
查看冲突依赖是否消除,可以看到冲突依赖仍然存在
刷新依赖即可解决
可以看到已经消除了冲突依赖
以上是关于使用Maven Helper解决Maven依赖冲突的主要内容,如果未能解决你的问题,请参考以下文章
aven依赖分析,jar包冲突解决利器intellij idea插件Maven Helper强烈建议安装
IDEA 查看jar依赖冲突插件maven helper使用教程