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

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

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

          而在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的源代碼,將這個(gè)變量有私有改為公有,再打包,問題可解決。

             
          2.在類路徑先將slf4j-api.jar 刪除,再導(dǎo)入同版本的slf4j-api-1.5.6.jar 和slf4j-log4j12-1.5.6.jar ,問題可解決。
          我遇到這個(gè)問題時(shí)用的是Hibernate3.6,是將hibernate-jpa-2.0-api-1.0.0.Final.jar包加進(jìn)去才解決了的。相同問題的朋友試試。
          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呀害死人  回復(fù)  更多評論
            
          主站蜘蛛池模板: 根河市| 长垣县| 富锦市| 东台市| 沐川县| 顺昌县| 浑源县| 行唐县| 扎赉特旗| 盈江县| 进贤县| 临城县| 亚东县| 临猗县| 丹凤县| 遂川县| 钟祥市| 岳普湖县| 新余市| 鹤山市| 咸丰县| 桂阳县| 昌吉市| 芷江| 灵台县| 玉屏| 扶风县| 玉山县| 江都市| 轮台县| 湖南省| 汉川市| 高碑店市| 米泉市| 邵东县| 略阳县| 营口市| 治多县| 黑龙江省| 镇雄县| 和平区|