java项目解决SLF4J: Class path contains multiple SLF4J bindings.问题

1.启动项目的时候报warn,虽然不影响项目的正常使用,但是很烦人,所以决定排除。

问题是两个不同的子包引用了同一个class,导致的问题。

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/D:/document/maven/repository/ch/qos/logback/logback-classic/1.1.8/logback-classic-1.1.8.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/D:/document/maven/repository/org/slf4j/slf4j-log4j12/1.7.22/slf4j-log4j12-1.7.22.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.

SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder]

2.将项目的依赖树导出,查看引用目标包的pom配置,将这个包排除掉。

dependency:tree -Doutput=dep.txt

3.去dep.txt文件搜索引用目标包的pom配置,发现有两个包所引用所在

+- com.****.openapi:openapi-sdk:jar:1.0.1-api1.2:compile
|  +- org.codehaus.jettison:jettison:jar:1.3.8:compile
|  |  \- stax:stax-api:jar:1.0.1:compile
|  +- commons-codec:commons-codec:jar:1.10:compile
|  +- com.google.code.gson:gson:jar:2.3.1:compile
|  +- org.slf4j:slf4j-api:jar:1.7.22:compile
|  +- org.slf4j:slf4j-log4j12:jar:1.7.22:compile
|  \- log4j:log4j:jar:1.2.17:compile

将其中一个包的slf4j-log4j12排除掉即可

4.没有warnning,排除依赖的pom

<exclusion>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
</exclusion>


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值