隨筆-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呀害死人  回復  更多評論
            
          主站蜘蛛池模板: 鸡泽县| 冀州市| 平乡县| 犍为县| 门头沟区| 武定县| 西乌珠穆沁旗| 张北县| 海安县| 从化市| 洪洞县| 宾阳县| 和静县| 巨鹿县| 西藏| 兰溪市| 五莲县| 广灵县| 玉环县| 河西区| 凤翔县| 五华县| 利川市| 甘南县| 天祝| 长汀县| 彰化县| 定结县| 渑池县| 海城市| 吉安市| 南皮县| 噶尔县| 万全县| 高邮市| 茶陵县| 宁陕县| 巍山| 四平市| 确山县| 龙州县|