首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

hibernate-distribution-3.3.1.GA 调度slf4j-api-1.5.6.jar 包导入

2012-11-05 
hibernate-distribution-3.3.1.GA 部署slf4j-api-1.5.6.jar 包导入错误: java.lang.IllegalAccessError: t

hibernate-distribution-3.3.1.GA 部署slf4j-api-1.5.6.jar 包导入

错误:
java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory

出现此错误,发现slf4j-api-1.5.6.jar 和 slf4j-nop-1.5.6.jar 包版本不一致所致。都导入1.5.6版本包,问题解决。

问题原因: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 ,问题可解决。

?

热点排行