org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/config/applicationContext.xml]: Invocation of init method failed; nested exception is org.hibernate.HibernateException: Could not instantiate cache implementation
……
……
……
先把这段异常信息google一把后,得到大部分的解决方案都说是包冲突,在经过一系列的试验发现根本就不是一回事,继续查找下列异常信息。
Caused by: org.hibernate.HibernateException: Could not instantiate cache implementation
……
……
……
Caused by: org.hibernate.cache.NoCachingEnabledException: Second-level cache is not enabled for usage [hibernate.cache.use_second_level_cache | hibernate.cache.use_query_cache]
隐约得知缓存配置方面出现问题,发现问题后顺着指示找到了applicationContext.xml文件中的这段配置,提示的意思大概为缓存不可用,在添加了缓存配置后一切正常。
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
<!-- 添加缓存配置-->
<prop key="hibernate.cache.provider_class">org.hibernate.cache.HashtableCacheProvider</prop>
</props>
</property>
<!-- hbm.xml文件加载方式-->
<property name="mappingLocations">
<list>
<value>classpath*:/com/train/entity/admin/hbm/*.hbm.xml</value>
<value>classpath*:/com/train/entity/common/hbm/*.hbm.xml</value>
</list>
</property>
</bean>