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下载。
分享到:
相关推荐
org.slf4j.impl.StaticLoggerBinder.class org.slf4j.impl.StaticMDCBinder.class org.slf4j.impl.StaticMarkerBinder.class org.slf4j.spi.LocationAwareLogger.class org.slf4j.spi.LoggerFactoryBinder.class org...
包含 slf4j-simple-1.7.25-sources ,slf4j-simple-1.7.25 ,slf4j-nop-1.7.25-sources,slf4j-nop-1.7.25,slf4j-api-1.7.25,slf4j-log4j12-1.7.25等
java高级处理日志工具org.slf4j.log4j.jar,可以和org.slf4j.jar结合起来使用
maven安装时必不可少的jar包、可代替1.6.2版本
java高级处理日志工具org.slf4j.jar,可以和org.slf4j.log4j结合起来使用
1.如果运行程序出现错误:“Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory”,这是因为项目缺少slf4j-api.jar和slf4j-log4j12.jar这两个jar包导致的错误。 2.如果运行程序...
SLF4J(Simple Logging Facade for Java)是Java中的一种日志抽象层,它提供了一个接口,允许用户在运行时动态地绑定到各种具体的日志框架,如Log4j、Java内置的日志或者Logback等。这个设计使得开发者可以在不修改...
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory 需要jar log4j-1.2.16.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar
META-INF/maven/org.slf4j/slf4j-api/pom.properties META-INF/maven/org.slf4j/slf4j-api/pom.xml org.slf4j.ILoggerFactory.class org.slf4j.IMarkerFactory.class org.slf4j.Logger.class org.slf4j....
描述中提到的"slf4j-api-1.7.26.jar"是SLF4J API的核心库,它包含所有开发者需要使用的接口和类,例如`org.slf4j.Logger`和`org.slf4j.LoggerFactory`。`Logger`接口提供了不同级别的日志记录方法,如`trace()`, `...
**Slf4j日志框架详解** Slf4j(Simple Logging Facade for Java)是一个用于日志系统的简单 facade,它允许最终用户在部署他们的应用时使用他们希望的日志库。Slf4j提供了一个统一的API,使得开发人员能够在不更换...
org.restlet.ext.slf4j.jar
hibernate的错误SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".的解决方法是:下载slf4j-nop.jar、slf4f-simple.jar、slf4j-log4j12.jar、slf4j-jdk14.jar或logback-classic.jar中某一个而且...
类org.slf4j.impl.StaticLoggerBinder并不在slf4j-api-1.5.2.jar包中,仔细查看每个与具体日志系统对应的jar包,就会发现,相应的jar包都有一个org.slf4j.impl.StaticLoggerBinder的实现,不同的实现返回与该日志...
NULL 博文链接:https://javajoy.iteye.com/blog/285894
Caused by: java.lang.ClassNotFoundException: org.slf4j.LoggerFactory 缺少此依赖包
1. **slf4j-api.jar**:这是SLF4J的核心API,包含了所有用于日志记录的方法,如`org.slf4j.Logger`和`org.slf4j.LoggerFactory`。 2. **slf4j-log4j12.jar**:这是一个绑定库,它将SLF4J API与Log4j日志实现连接...
Maven坐标:org.slf4j:slf4j-api:1.7.30; 标签:slf4j、api、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持...
1. **日志记录接口**:SLF4J提供了多个接口,如`org.slf4j.Logger`,它是日志记录的核心接口,允许开发者进行日志输出。 2. **绑定机制**:SLF4J并不实现日志记录功能,而是通过绑定机制与具体的日志实现(如Logback...