java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory


 一、問題描述:

搭建hibernate環境時,使用hibernate-distribution-3.3.1.GA-dist和slf4j-1.7.7。配置文件和程序OK之后,運行程序出現如下問題:

 1 java.lang.IllegalAccessError: tried to access field org.slf4j.impl.StaticLoggerBinder.SINGLETON from class org.slf4j.LoggerFactory
 2     at org.slf4j.LoggerFactory.<clinit>(LoggerFactory.java:60)
 3     at org.hibernate.cfg.Configuration.<clinit>(Configuration.java:151)
 4     at com.pers.test.CustomerTest.<clinit>(CustomerTest.java:33)
 5     at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
 6     at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
 7     at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
 8     at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
 9     at org.junit.runners.BlockJUnit4ClassRunner.createTest(BlockJUnit4ClassRunner.java:217)
10     at org.junit.runners.BlockJUnit4ClassRunner$1.runReflectiveCall(BlockJUnit4ClassRunner.java:266)
11     at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
12     at org.junit.runners.BlockJUnit4ClassRunner.methodBlock(BlockJUnit4ClassRunner.java:263)
13     at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
14     at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
15     at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
16     at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
17     at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
18     at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
19     at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
20     at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
21     at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
22     at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
23     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
24     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
25     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
26     at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

 

二、原因分析:jar包版本沖突

類 org.slf4j.impl.StaticLoggerBinder在hibernate-distribution-3.3.1.GA-dist\hibernate-distribution-3.3.1.GA\lib\required\slf4j-api-1.5.2.jar中是類的公有靜態變量: 

public static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();

而在slf4j-1.7.7\slf4j-log4j12-1.7.7.jar中是私有變量: 

private static final StaticLoggerBinder SINGLETON = new StaticLoggerBinder();

解決方案:1.修改slf的源代碼,將這個變量由私有改為公有,再打包,問題可解決。

                 2. 將slf4j-api-1.5.2.jar替換為slf4j-1.7.7\slf4j-api-1.7.7.jar,問題可解決。

 

三、jar包附圖

  如果需要注解或和其他框架整合,則另行導入,各jar作用不再贅述。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM