依赖包冲突介绍
问题描述
- Correct the classpath of your application so that it contains a single, compatible version of *******
- 当新引入一个依赖之后发现项目无法运行,大概率是发生了依赖包冲突问题
- 依赖包冲突主要原因
- 项目中原本有一个A依赖版本为1.0;新引进的依赖中使用到了A依赖的2.0版本
- maven对于同一个依赖包的不同版本的处理方法是:以第一个扫描到的包的版本为准
- 也就是说新引进的依赖也只能使用A依赖的1.0版本
问题
在于新依赖要使用2.0版本的A依赖,情况更严重的话,要使用2.0的A依赖中方法,在1.0依赖中没有此方法- 导致新依赖的组件无法运行
解决方案
- 第一种,将新加的依赖包中的冲突的依赖排除掉,这样就是使用项目中原来的依赖的版本,在依赖中加入
<dependency>
<groupId>***</groupId>
<artifactId>***</artifactId>
<version>***</version>
<exclusions>
//要排除的依赖
<exclusion>
<artifactId>*</artifactId>
<groupId>**</groupId>
</exclusion>
</exclusions>
</dependency>
适用场景:新依赖加入后,原有项目代码无法运行
- 第二种,指定一个所有依赖都可以使用的依赖版本,所有依赖此依赖的依赖都是用这一版本的依赖,例如,若果guava包版本冲突,直接使用以下配置
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>20.0</version>
</dependency>
适用场景:依赖可以确定都使用同一个版本
- 第三种,调整依赖的顺序,因为Maven的规则是优先顺序扫描,同时以扫描到的第一个依赖版本为准,因此,调整依赖的顺序可以调整使用哪一个包中的依赖版本
我遇到的问题
The method's class, com.google.common.collect.FluentIterable, is available from the following locations
问题分析
我新加入的swagger组件中里边需要某个类,这个类在guave20.0
版本中,但是我的项目之前引入了guave18.0
,因此我的swagger依赖也只能使用18.0
,但是18.0
中没有swagger依赖需要的某个类,因此项目无法运行
解决方案
- 第一,我发现我的项目中之前引入的
guave
依赖没有指定版本,而新的依赖需要guave 20.0
,我决定在之前项目引入的guave
依赖处指定版本20.0
,希望可以成功 - 第二,我发现虽然我指定了版本,但是运行的时候还是报错
guave18.0
的jar包没有那个类,我的本地依赖库中也还是guave18.0
版本的jar包,继续解决原因
因为我是多模块项目,存在模块间的依赖问题,单模块项目应该可以解决
- 第三,多模块项目的依赖问题,最终发现是由于我只在指定
guava 20.0
版本,多模块项目中可能其他项目会有其他版本的guava
,而我新的依赖强依赖于guava 20.0
,因此将guava 20.0配置在父模块中
<guava.version>20.0</guava.version>
最终成功运行!!!