Spring Boot + Maven依赖包冲突解决方法

依赖包冲突介绍

问题描述

  • 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配置在父模块中
       20.0

最终成功运行!!!

你可能感兴趣的:(笔记)