使用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包冲突的原因主要有两种

  1. 第一种是一个项目,依赖了同一个项目的两个版本。
  2. 第二种冲突原因是不同项目中,出现了相同的类。何为相同的类,即类的全限定名相同。

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使用Maven Helper插件排除依赖冲突

IDEA 查看jar依赖冲突插件maven helper使用教程

IDEA 查看jar依赖冲突插件maven helper使用教程

IDEA依赖冲突分析神器—Maven Helper

Maven Helper快速解决冲突问题