一、問題描述:
搭建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作用不再贅述。