Java异常 #Class path contains multiple SLF4J bindings.警告解决

1.异常现象

启动 Maven 项目时,抛出警告信息:

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/D:/Tp_Mylocal/20_Install/maven/repo/org/slf4j/slf4j-log4j12/1.7.20/slf4j-log4j12-1.7.20.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/D:/Tp_Mylocal/20_Install/maven/repo/ch/qos/logback/logback-classic/1.1.7/logback-classic-1.1.7.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Detected both log4j-over-slf4j.jar AND bound slf4j-log4j12.jar on the class path, preempting StackOverflowError. 
SLF4J: See also http://www.slf4j.org/codes.html#log4jDelegationLoop for more details.

 

2.排查分析

从报出来的警告信息来看,大致意思是,pom.xml 引入的包 slf4j-log4j12-1.7.20.jar 和包 logback-classic-1.1.7.jar 中,都找到了 /org/slf4j/impl/StaticLoggerBinder.class 这个类,不知道用哪个,于是发生了冲突。
 

3.解决方案

既然是 jar 包冲突,那就找到 pom.xml 文件,我们来排除一下:
1) 找到 pom.xml 文件,打开,然后右键,在菜单中选择 [Diagrams] -> [Show Dependencies]在这里插入图片描述
2) 弹出一画复杂交错的依赖图,触目惊心,哭笑不得
哭笑不得与置之不理
3) 攻而克之,Ctrl + F,搜索 slf4j-log4j12,找到 slf4j-log4j12 后,右键,把它 Exclude 掉
在这里插入图片描述
好了,查看 pom.xml 文件,刚刚排除掉的 jar 已经自动生成了 exclusion 代码,如:

<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>${zookeeper.version}</version>
    <exclusions>
        <exclusion>
            <artifactId>slf4j-log4j12</artifactId>
            <groupId>org.slf4j</groupId>
        </exclusion>
    </exclusions>
</dependency>

或者,也可以手动在 pom.xml 文件中排除相关依赖。

注意:

  1. log4j-over-slf4j.jarslf4j-log4j12.jar 是跟 Java 日志系统相关的两个 jar 包,当它们同时出现在 classpath 下时,可能会引起堆栈溢出异常。
  2. 如果你用的是 logback 日志,要排除的是 slf4j-log4j12.jar 包,不要排除 logback-classic.jar 包。
引用\[1\]和\[2\]中提到了相同的错误信息,即"Class path contains multiple SLF4J bindings"。这个错误通常是由于项目中存在多个SLF4J实现类的绑定引起的。解决这个问题的方法是删除其中一个实现类的依赖。 具体的解决方案如下: 1. 首先,确定你想要使用的SLF4J实现类是哪个。在引用\[1\]中,想要使用的是slf4j-log4j12-1.6.4.jar,而在引用\[2\]中,想要使用的是logback-classic-1.2.3.jar。 2. 打开你的项目的依赖配置文件(比如pom.xml或build.gradle),找到与SLF4J相关的依赖项。 3. 删除其中一个实现类的依赖项。如果你想要使用slf4j-log4j12,那么删除logback-classic的依赖项;如果你想要使用logback-classic,那么删除log4j-slf4j-impl的依赖项。 4. 保存并重新构建你的项目。 这样,你就解决了"Class path contains multiple SLF4J bindings"的问题。请注意,如果你删除了一个实现类的依赖项,你可能需要相应地调整你的日志配置文件,以确保日志记录正常工作。 #### 引用[.reference_title] - *1* [遇到Class path contains multiple SLF4J bindings.该如何解决](https://blog.csdn.net/chuyouyinghe/article/details/79134894)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [SLF4J: Class path contains multiple SLF4J bindings.](https://blog.csdn.net/qq_39323945/article/details/125765205)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Class path contains multiple SLF4J bindings.问题原因及解决方案](https://blog.csdn.net/hsuehgw/article/details/128057054)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值