maven依赖地狱:java.lang.NoSuchMethodError

时间:2018-05-18 14:56:09

标签: java maven spring-boot dependency-management

我正在尝试将我们现有的一个maven项目转换为spring boot。我的项目中没有任何编译错误,但是当我尝试运行它时,我收到以下错误:

Exception in thread "main" java.lang.NoSuchMethodError: org.springframework.util.MultiValueMap.addAll(Ljava/lang/Object;Ljava/util/List;)V
at org.springframework.core.io.support.SpringFactoriesLoader.loadSpringFactories(SpringFactoriesLoader.java:140)
at org.springframework.core.io.support.SpringFactoriesLoader.loadFactoryNames(SpringFactoriesLoader.java:119)
at org.springframework.boot.SpringApplication.getSpringFactoriesInstances(SpringApplication.java:426)
at org.springframework.boot.SpringApplication.getSpringFactoriesInstances(SpringApplication.java:418)
at org.springframework.boot.SpringApplication.<init>(SpringApplication.java:266)
at org.springframework.boot.SpringApplication.<init>(SpringApplication.java:247)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1255)
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1243)
at com.myorg.MyMainClass ...

我的POM:

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.2.RELEASE</version>
    <relativePath /> <!-- lookup parent from repository -->
</parent>


<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

    <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.16</version>
            <scope>compile</scope>
        </dependency>

    <dependency>
        <groupId>couple of our other internal projects</groupId>
        **One of these projects is using spring-context and spring-orm** dependencies. 
    </dependency>


</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

由于我自己的项目中的spring依赖项是在其他项目之前声明的,我认为它会覆盖任何这些传递依赖项。

我浪费了整整一天的时间。有人可以帮忙吗?

1 个答案:

答案 0 :(得分:0)

  

由于我自己的项目中的spring依赖项在其他项目之前被声明,所以我以为它将覆盖所有这些传递性依赖项。

这实际上是问题所在。您的项目决定要包含的内容,但是某些依赖项需要不同的版本。他们仍在尝试调用其版本中存在的方法,而不是您的版本中存在的方法,并且找不到该方法,因为您已强行排除了其版本。除非您确信两个版本兼容,否则不要这样做!

解决方案:

  1. 在单个版本上对齐并使用
  2. 使用更多兼容版本
  3. 通过阴影(请参见this post)或类似的机制包含两个版本