264

我收到以下错误。似乎有多个日志框架绑定到 slf4j。不知道如何解决这个问题。任何帮助是极大的赞赏。

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/C:/Users/admin/.m2/repository/org/slf4j/slf4j-log4j12/1.6.4/slf4j-log4j12-1.6.4.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/C:/Users/admin/.m2/repository/org/slf4j/slf4j-log4j12/1.6.1/slf4j-log4j12-1.6.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
4

17 回答 17

155

通过在导致冲突的依赖项(pom.xml)中添加以下排除项来解决。

<exclusions>
    <exclusion>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
    </exclusion>
</exclusions> 
于 2014-03-25T15:08:30.597 回答
77

梯度版本;

configurations.all {
    exclude module: 'slf4j-log4j12'
}
于 2014-09-05T22:21:10.090 回答
30

该错误可能会提供更多这样的信息(尽管您的 jar 名称可能不同)

SLF4J:在 [jar:file:/D:/Java/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/org/slf4j/impl/StaticLoggerBinder 中找到绑定.class] SLF4J:在 [jar:file:/D:/Java/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.8.2/log4j-slf4j-impl-2.8.2.jar 中找到绑定!/org/slf4j/impl/StaticLoggerBinder.class]

注意到冲突来自两个罐子,名为logback-classic-1.2.3log4j-slf4j-impl-2.8.2.jar

mvn dependency:tree在这个项目 pom.xml 父文件夹中运行,给出:

依赖树冲突

现在选择一个你想忽略的(可能需要一个微妙的努力,我需要更多的帮助)

我决定不使用从spring-boot-starter-data-jpa(顶级依赖项)通过spring-boot-starter和 through导入的那个spring-boot-starter-logging,pom 变为:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

在上面的 pomspring-boot-starter-data-jpa中将使用spring-boot-starter同一文件中的配置,其中不包括logging(它包含logback

于 2018-03-14T04:19:26.563 回答
11

SBT 版本:

附加exclude("org.slf4j", "slf4j-log4j12")到传递包含的依赖项slf4j-log4j12。例如,当使用带有 Log4j 2.6 的 Spark 时:

libraryDependencies ++= Seq(
  // One SLF4J implementation (log4j-slf4j-impl) is here:
  "org.apache.logging.log4j" % "log4j-api" % "2.6.1",
  "org.apache.logging.log4j" % "log4j-core" % "2.6.1",
  "org.apache.logging.log4j" % "log4j-slf4j-impl" % "2.6.1",
  // The other implementation (slf4j-log4j12) would be transitively
  // included by Spark. Prevent that with exclude().
  "org.apache.spark" %% "spark-core" % "1.5.1" exclude("org.slf4j", "slf4j-log4j12")
)
于 2016-06-28T11:18:11.183 回答
7

1.找到冲突的jar

如果无法从警告中识别依赖关系,则可以使用以下命令来识别冲突的 jar

mvn dependency: tree

这将显示项目的依赖关系树以及与slf4j-log4j12JAR 绑定的另一个依赖关系。

  1. 解析度

现在我们知道了有问题的依赖项,我们需要做的就是slf4j-log4j12从该依赖项中排除 JAR。

Ex - 如果spring-security依赖项还与slf4j-log4j12JAR 绑定了另一个绑定,那么我们需要从依赖项中排除slf4j-log4j12JAR 。spring-security

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
           <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
    </dependency>

注意 -在某些情况下,多个依赖项已与slf4j-log4j12JAR 绑定,您不需要为每个已拉入的依赖项添加排除项。您只需添加排除依赖项与已放置在的依赖项第一的。

前任 -

<dependencies>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

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

</dependencies>
于 2020-11-08T16:14:58.340 回答
4

我只是忽略/删除了那个 jar 文件。

在此处输入图像描述

于 2016-07-14T20:53:59.753 回答
4
<!--<dependency>-->
     <!--<groupId>org.springframework.boot</groupId>-->
     <!--<artifactId>spring-boot-starter-log4j2</artifactId>-->
<!--</dependency>-->

我通过删除这个解决了:spring-boot-starter-log4j2

于 2018-08-30T02:53:20.947 回答
3

这是因为 StaticLoggerBinder.class 类属于两个不同的 jar 的问题。此类从 logback-classic-1.2.3.jar 引用,同样的类也从 log4j-slf4j-impl-2.10.0.jar 引用。类路径中的两个 jar。因此,他们之间存在冲突。这是日志文件未生成的原因,即使类路径 [src/main/resource] 中的 log4j2.xml 文件也是如此。

我们已经选择了一个 jar,我建议使用 log4j-slf4j-impl-2.10.0.jar 文件并排除 logback-classic-1.2.3.jar 文件。解决方法:打开pom文件,查看依赖层次结构[eclipse]或者运行
mvn dependency:tree命令,找出下载依赖的依赖树和依赖源。找到冲突的依赖项并排除它们。对于 Springboot 应用程序,试试这个。

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                    <exclusion>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-starter-logging</artifactId>
                    </exclusion>
                </exclusions>
        </dependency>
    <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

This is working fine for me after struggling a lots.
于 2019-06-03T11:03:44.870 回答
3

只使用必需的依赖项,而不是全部:)))。对我来说,对于日志记录过程的正常工作,您需要此依赖项从 pom.xml 中排除其他依赖项

<dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-api</artifactId>
        <version>1.7.5</version>
    </dependency>

    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <version>1.1.8</version>
    </dependency>

    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
        <version>1.1.8</version>
    </dependency>
于 2016-12-30T08:13:34.960 回答
2

对我来说,答案是强制 Maven 重建。在 Eclipse 中:

  1. 右键单击项目-> Maven -> 禁用 Maven 自然
  2. 右键单击项目-> Spring Tools > 更新 Maven 依赖项
  3. 右键单击项目-> 配置 > 转换 Maven 项目
于 2019-03-18T13:43:14.253 回答
2

对我来说,从 log4j 切换到 logback 后,它原来是一个 Eclipse/Maven 问题。查看您的.classpath文件并搜索字符串"log4j"

就我而言,我在那里有以下内容: <classpathentry kind="var" path="M2_REPO/org/slf4j/slf4j-log4j12/1.7.1/slf4j-log4j12-1.7.1.jar"/> <classpathentry kind="var" path="M2_REPO/log4j/log4j/1.2.17/log4j-1.2.17.jar" />

从文件中删除这些条目(或者您可以重新生成它)解决了这个问题。

于 2018-08-20T19:37:26.133 回答
2

... org.codehaus.mojo cobertura-maven-plugin 2.7 测试 ch.qos.logback logback-classic 工具 com.sun ...

##我修复了这个

... org.codehaus.mojo cobertura-maven-plugin 2.7 测试 ch.qos.logback logback-classic 工具 com.sun ...

于 2018-04-27T09:43:52.023 回答
0

我通过从我的 Intellij 项目转到项目结构解决了这个问题。我删除了名为: Maven: org.apache.logging.log4j:log4j-to-slf4j-impl:2.14.1 的文件 在此处输入图像描述

此文件未在此图片中显示。您可能会看到两个称为log4j-to-slf4j 的库。删除一个,你就可以走了。

于 2022-01-27T04:59:47.220 回答
0

我在一个非 Maven 项目中遇到了这个问题,两个依赖的 jar 每个都包含一个 slf4j。我通过删除一个依赖的 jar 来解决,编译项目(当然会失败)然后添加删除的一个。

于 2020-09-25T13:16:04.367 回答
0

我有同样的问题。在我的 pom.xml 我有两个

 <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-simple</artifactId>
        <version>1.7.28</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <version>2.2.1.RELEASE</version>
    </dependency>

当我删除 spring-boot-starter-web 依赖项时,问题就解决了。

于 2019-11-10T12:43:47.170 回答
-1

<scope>provided</scope>和的组合<exclusions>对我不起作用。

我不得不使用这个:

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <scope>system</scope>
    <systemPath>${project.basedir}/empty.jar</systemPath>
</dependency>

一个 jar 文件在哪里empty.jar,里面什么都没有。

于 2019-10-03T05:38:14.967 回答
-5

似乎删除 .m2 目录和:

mvn install -DskipTests -T 4为我解决了这个问题。

于 2015-10-07T18:42:07.567 回答