注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

让一切都逝去吧

排骨炖泥菜/猪肝炒苹果/鱼籽狗肉汤/狗头薏米汤

 
 
 

日志

 
 

org.slf4j.impl.StaticLoggerBinder.SINGLETON无法访问  

2011-09-14 17:15:18|  分类: Java |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
      在使用Shiro是出现错误:
tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory

       tomcat启动是出现错误,搜索资料发现其他一些项目也出现同样问题,原因在于 slf4j-log4j12-1.5.6.jar 这个包,其静态变量SINGLETON是私有的。
private static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();
      网上的描述和解决方法是:

类 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 ,问题可解决。

      源代码我是懒得去改,全部使用 1.5.6 版本,在我的项目同样出错。其实我对 slf4j 的版本是没有要求的,于是退回到 slf4j-api-1.5.5.jar,其中这一行变量是公有的。

public static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();

      于是使用 slf4j-api-1.5.5.jar 和 slf4j-log4j12-1.5.5.jar 问题即解决。

  评论这张
 
阅读(2535)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017