隨筆-13  評論-12  文章-3  trackbacks-0
          問題描述:學習 Hibernate持久化技術時,使用hibernate-annotations-3.4.0.GA版本做實驗,做好了程序和配置文件后,運行程序出現 java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory錯誤。

          問題原因:jar文件版本沖突

          類 org.slf4j.impl.StaticLoggerBinder在slf4j
          -api 中是類的公有靜態變量:
          public static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();
          以上是在網絡上找的答案,也有很多人試過的,但是我遇到這個問題時,使用的Hibernate是3.6的,這種方法不適合。
          后來我將 hibernate
          -jpa-2.0-api-1.0.0.Final.jar 包也加了進來之后,程序就好了。具體原因還在糾結.

          而在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 ,問題可解決。
          我遇到這個問題時用的是Hibernate3.6,是將hibernate-jpa-2.0-api-1.0.0.Final.jar包加進去才解決了的。相同問題的朋友試試。
          posted on 2010-11-21 18:55 zeroline 閱讀(10057) 評論(1)  編輯  收藏 所屬分類: bug

          評論:
          # re: java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory 2012-02-16 15:17 | skly
          謝謝,jar呀害死人  回復  更多評論
            
          主站蜘蛛池模板: 黄山市| 黄陵县| 太和县| 平远县| 涿鹿县| 登封市| 滦平县| 郑州市| 嵊泗县| 临漳县| 杭锦旗| 分宜县| 恩平市| 达州市| 崇仁县| 盐城市| 阿鲁科尔沁旗| 延长县| 忻城县| 太仓市| 太谷县| 南充市| 永嘉县| 四会市| 大名县| 桃源县| 襄城县| 承德县| 商河县| 龙陵县| 宣武区| 阳信县| 星座| 公主岭市| 墨竹工卡县| 阿巴嘎旗| 宁德市| 静安区| 双辽市| 同江市| 新巴尔虎右旗|