今天新添加一个sql表,并设置了herbinate持久化类和map关系映射文件后,运行服务器后报出了如下的错误:
一月 15, 2018 4:32:04 下午 org.springframework.context.support.AbstractApplicationContext doClose
信息: Closing Root WebApplicationContext: startup date [Mon Jan 15 16:32:00 CST 2018]; root of context hierarchy
一月 15, 2018 4:32:04 下午 org.springframework.context.support.AbstractApplicationContext doClose
警告: Exception thrown from LifecycleProcessor on context close
java.lang.IllegalStateException: LifecycleProcessor not initialized - call 'refresh' before invoking lifecycle methods via the context: Root WebApplicationContext: startup date [Mon Jan 15 16:32:00 CST 2018]; root of context hierarchy
at org.springframework.context.support.AbstractApplicationContext.getLifecycleProcessor(AbstractApplicationContext.java:359)
......
出现这种问题的原因很多,网上给出的大多数原因是spring的jar包丢失,或者是JDK的版本与 tomcat不兼容等。但是我之前也创建过sql表,也配置相应的map映射文件,都没有出现问题,所以网上的这种方案对我而言没什么帮助。
后来参考了这篇博客:spring入门常见的问题及解决办法后,才明白自己错在了哪。原来是在编写业务逻辑层中,忘记添加spring的set依赖注入了!
在业务逻辑层中声明一个xxDao对象后,记得要添加对应的setxxDao函数,如下所示:
//注入对象springDao
private SpringDao springDao;
//一定要写被注入对象的set方法
public void setSpringDao(SpringDao springDao) {
this.springDao = springDao;
}
吃一堑长一智吧。