问题
Spring3.0.0.RELEASE搭配Hibernate3.3.2.GA,构建事务案例,启动报错。
日志异常如下:
Caused by: java.lang.NoClassDefFoundError: org/hibernate/annotations/Entity
at org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean.<init>(AnnotationSessionFactoryBean.java:93)
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126)
... 27 more
Caused by: java.lang.ClassNotFoundException: org.hibernate.annotations.Entity
at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
... 33 more
分析
从日志AnnotationSessionFactoryBean.java类出发,进行分析,确实是找不到类Entity,由此可见,是少导入了什么包:
在网上搜了一遍,发现百度前几个都不靠谱。
后来突然想到hibernate除了hibernate-core以外,还有别的包,于是搜索了一下mvn库。马上就找到了:
于是,根据相同日期,找到对应的版本3.4.0。
导入后,果然发现了该类:
解决
在pom.xml文件中,导入以下依赖即可。
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-entitymanager</artifactId>
<version>3.4.0.GA</version>
</dependency>
文章结束。