Spring启动后获取所有拥有特定注解的Bean实例代码
本文研究的主要是Spring启动后获取所有拥有特定注解的Bean,具体如下。
最近项目中遇到一个业务场景,就是在Spring容器启动后获取所有的Bean中实现了一个特定接口的对象,第一个想到的是ApplicationContextAware,在setApplicationContext中去通过ctx获取所有的bean,后来发现好像逻辑不对,这个方法不是在所有bean初始化完成后实现的,后来试了一下看看有没有什么Listener之类的,发现了好东西ApplicationListener,然后百度一下ApplicationListener用法,原来有一大堆例子,我也记录一下我的例子好了。
很简单,只要实现ApplicationListener<ContextRefreshedEvent>
接口,然后把实现类进行@Component即可,代码如下:
@Component public class ContextRefreshedListener implements ApplicationListener<ContextRefreshedEvent> { @Override public void onApplicationEvent(ContextRefreshedEvent event) { // 根容器为Spring容器 if(event.getApplicationContext().getParent()==null){ Map<String,Object> beans = event.getApplicationContext().getBeansWithAnnotation(IMobile.class); for (Object bean:beans.values()){ System.err.println(bean==null?"null":bean.getClass().getName()); } System.err.println("=====ContextRefreshedEvent====="+event.getSource().getClass().getName()); } } }
其中,通过event.getApplicationContext().getBeansWithAnnotation
获取到所有拥有特定注解的Beans集合,然后遍历所有bean实现业务场景。
总结思考:这样的功能可以实现系统参数的初始化,获取系统中所有接口服务清单等一系列需要在Spring启动后初始化的功能。
延生一下:除了以上启动后事件外,还有其他三个事件
Closed在关闭容器的时候调用,Started理论上在容器启动的时候调用,Stopped理论上在容器关闭的时候调用。
我通过TomcatServer进行启动停止,只看到了Refreshed和Closed,不知道为啥,有空再继续研究
总结
以上就是本文关于Spring启动后获取所有拥有特定注解的Bean实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
相关文章
Spring cloud踩坑记录之使用feignclient远程调用服务404的方法
这篇文章主要给大家介绍了关于Spring cloud踩坑记录之使用feignclient远程调用服务404的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2018-11-11Spring Boot console log 格式自定义方式
这篇文章主要介绍了Spring Boot console log 格式自定义方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-07-07
最新评论