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包则未被使用,这就是所谓的依赖冲突。apache
在大多数时候,依赖冲突可能并不会对系统形成什么异常,由于Maven始终选择了一个Jar包来使用。可是,不排除在某些特定条件下,会出现相似找不到类的异常,因此,只要存在依赖冲突,在我看来,最好仍是解决掉,不要给系统留下隐患。api
解决依赖冲突的方法,就是使用Maven提供的<exclusion>标签,<exclusion>标签须要放在<exclusions>标签内部,就像下面这样:工具
<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
版本不一样,因此咱们使用<exclusion>标签排除掉log4j-core
所依赖的log4j-api
,这样Maven就不会下载log4j-core
所依赖的log4j-api
了,也就保证了咱们的项目中只有一个版本的log4j-api
。spa
看到这里,你可能会有一个疑问。如何才能知道本身的项目中哪些依赖的Jar包冲突了呢?Maven Helper这个InteliJ IDEA的插件帮咱们解决了这个问题。插件的安装方法我就不讲了,既然你都会Maven了,我相信你也是会安装插件的。插件
在插件安装好以后,咱们打开pom.xml文件,在底部会多出一个Dependency Analyzer选项3d
点开这个选项code
找到冲突,点击右键,而后选择Exclude便可排除冲突版本的Jar包。xml
除了使用Maven Helper查看依赖冲突,也可使用IDEA提供的方法——Maven依赖结构图,打开Maven窗口,选择Dependencies,而后点击那个图标(Show Dependencies)或者使用快捷键(Ctrl+Alt+Shift+U),便可打开Maven依赖关系结构图blog
在图中,咱们能够看到有一些红色的实线,这些红色实线就是依赖冲突,蓝色实线则是正常的依赖。ci
若文章有任何问题,欢迎留言指出——做者博客:桔子笔记