码迷,mamicode.com
首页 > 移动开发 > 详细

Spring 监听器 ApplicationListener 执行了3遍

时间:2015-07-15 11:06:58      阅读:336      评论:0      收藏:0      [点我收藏+]

标签:spring   监听器   初始化   

前提

项目使用了 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遍

标签:spring   监听器   初始化   

原文地址:http://blog.csdn.net/zhanlanmg/article/details/46889955

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!