隨筆-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 閱讀(10066) 評論(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呀害死人  回復  更多評論
            
          主站蜘蛛池模板: 通道| 汝城县| 海口市| 邛崃市| 崇义县| 吉木萨尔县| 普陀区| 南漳县| 北京市| 磴口县| 武穴市| 拉萨市| 冕宁县| 德钦县| 台江县| 六盘水市| 长顺县| 平南县| 壤塘县| 潜江市| 富裕县| 香港| 大荔县| 沾益县| 乾安县| 桑日县| 会昌县| 拉孜县| 洪湖市| 宽甸| 铜鼓县| 西充县| 榆社县| 亳州市| 剑川县| 桓仁| 固阳县| 龙游县| 丰城市| 安远县| 成武县|