您的位置:首页 > Web前端

发生LifecycleProcessor not initialized - call 'refresh' ... 问题的可能原因

2018-01-15 16:50 821 查看
今天新添加一个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;
}


吃一堑长一智吧。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐