这个扩展接口的主要目的是允许我们对ConfigurableApplicationContext的实例做额外的初始化操作
调用这个接口之前
ApplicationContext上下文已经创建,并且 BeanFactory也创建了
public void initialize(ConfigurableApplicationContext applicationContext){
}
因为是对ApplicationContext进行初始化,所以只可以修改上下文的参数。
比如
1、添加自定义事件监听器(非SpringBoot启动过程中的事件监听器)
2、添加BeanFactory的后置处理器 (一般不在这里添加)
注意:不能增加SpringBoot启动过程中的对应事件的监听器,
比如想要增加对ApplicationPreparedEvent事件的监听器,拿不到listeners监听器类,没办法添加进去
触发时间:
prepareContext()方法中执行
ApplicationEnvironmentPreparedEvent事件上下文环境准备之后
ApplicationPreparedEvent事件之前
添加BeanFactory的后置处理器,一般情况不在这里添加,
直接申明一个实现 后置处理器接口的 bean,就可以被正常使用。
使用例子
比如springBoot内置的initializer初始化器
META-INF/spring.factories文件配置,ApplicationContextInitializer变量指定的自定义初始化器类名
# Application Context Initializers
org.springframework.context.ApplicationContextInitializer=\
org.springframework.boot.context.ConfigurationWarningsApplicationContextInitializer,\
org.springframework.boot.context.ContextIdApplicationContextInitializer,\
比如下面
RSocketPortInfoApplicationContextInitializer
1、添加了一个 RSocketServerInitializedEvent事件的 监听器到 ApplicationContext中。
2、可以在后面业务代码中调用下面方法进行事件发布。再由监听器处理这个事件。
ApplicationContext.publishEvent(new RSocketServerInitializedEvent(xxxx))
为RSocketServer服务器实际监听的端口设置环境属性。
可以使用@Value将属性“ local.rsocket.server.port”直接注入测试中,也可以通过环境获取。
新增applicationListener到上下文中,用于监听RSocketServerInitializedEvent事件。然后再触发事件时,
将服务器RSocketServerInitializedEvent.getServer().address().getPort()端口
号值设置到 local.rsocket.server.port 上下文环境属性key中。用于在后面用@Value注解方式获取值