org.slf4j.impl.StaticLoggerBinder.SINGLETON

tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory

 

问题描述:在项目启动时出现错误。

 

于是搜了一下发现是jar文件的版本冲突引起的。

 

具体讲是 hibernate-commons-annotations-3.1.x.GA-sources.jar 和 slf4j-api-1.4.2.jar 引起的。

 

网上的描述和解决方法是:

 

类 org.slf4j.impl.StaticLoggerBinder在slf4j-api 中是类的公有静态变量:
public static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();

而在slf4j-log4j12(slf4j-nop.jar, slf4j-simple.jar, slf4j-log4j12.jar, slf4j-jdk14.jar or logback-classic.jar其中之一)中确是私有变量:
private static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();


解决方案:

 

1.修改slf的源代码,将这个变量有私有改为公有,再打包,问题可解决。

 

2.在类路径先将slf4j-api.jar 删除,再导入同版本的slf4j-api-1.5.6.jar 和slf4j-log4j12-1.5.6.jar ,问题可解决。

 

由于我们使用maven来管理项目jar是不能修改的,而且mvn package时候会拷贝一份slf4j-jdk14.jar到lib下,每次都覆盖太麻烦了。

 

所以,如果你用maven来管理项目就可以:

 

1、找到 M2_HOME\repository\org\hibernate\hibernate-commons-annotations\3.1.x.GA\hibernate-commons-annotations-3.1.0.GA.pom 文件

 

修改依赖项目

 

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

 

将原来的1.4.2改为1.5.6

 

2、下载1.5.6版的jar,在有pom.xml的目录下执行:

 

mvn install:install-file -DgroupId=org.slf4j -DartifactId=slf4j-api -Dversion=1.5.6 -Dpackaging=jar -Dfile=jar所在的目录

 

然后执行 mvn eclipse:eclipse -e 集成一下。

 

3、看一下结果会发现:问题就被ko了!

 

当然,以后为了保险起见,我们需要同时导入 slf4j-api和slf4j-log4j12包,那么可以修改hibernate-commons-annotations-3.1.0.GA.pom:

 

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-log4j12</artifactId>
    <version>1.5.6</version>
</dependency>

(因为 slf4j-log4j12有依赖slf4j-api,所以也将其导入了) 

 

另附 slf4j 全部的jar和resource下载。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值