项目使用了 Spring 框架,同时也使用了 Spring MVC 。
然后在一个类里面实现了 ApplicationListener 接口,用于在初始化完成后做一些事情,但是通过打印日志,发现它执行了3次,其中一次是Spring 框架初始化时执行,另外两次是在项目启动成功后,加载 projectname-servlet (也就是Spring MVC)时执行的。
通过打断点看到,这两次执行中,onApplicationEvent(ApplicationEvent applicationEvent)方法中的 applicationEvent 对象值不同,第一次是 Root WebApplicationContext
后两次都是项目名称。不确定为什么项目名称执行了两次,猜测一下,可能是spring会扫描多次整个项目,以免遗漏了注解过的类。最后一次没有再加载到新的类则停止了。(此段是YY的)
我使用的是spring4
可以用这样的方法处理,判断一下是不是根对象初始化,是的话就执行,否则不执行。
@Override
public void onApplicationEvent(ApplicationEvent applicationEvent) {
try {
//只在初始化“根上下文”的时候执行
if (applicationEvent.getSource() instanceof XmlWebApplicationContext) {
if (((XmlWebApplicationContext) applicationEvent.getSource()).getDisplayName().equals("Root WebApplicationContext")) {
//……你的代码
}
}
} catch (Exception e) {
log.error("((XmlWebApplicationContext) applicationEvent.getSource()).getDisplayName() 执行失败,请检查Spring版本是否支持");
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
Spring 监听器 ApplicationListener 执行了3遍
原文:http://blog.csdn.net/zhanlanmg/article/details/46889955