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下载。