05、SpringBoot事件监听
Java中的事件监听机制定义了以下几个角色:
- 事件:Event,继承 java.util.EventObject 类的对象
- 事件源:Source ,任意对象Object
- 监听器:Listener,实现 java.util.EventListener 接口 的对象
SpringBoot 在项目启动时,会对几个监听器进行回调,我们可以实现这些监听器接口,在项目启动时完成一些操作:
ApplicationContextInitializer、SpringApplicationRunListener、CommandLineRunner、ApplicationRunner
自定义监听器的启动时机:ApplicationRunner和CommandLineRunner都是当项目启动后执行,使用@Component放入容器即可使用。
ApplicationRunner使用案例:#
package com.itheima.springbootlistener.listener; import org.springframework.boot.ApplicationArguments; import org.springframework.boot.ApplicationRunner; import org.springframework.stereotype.Component; import java.util.Arrays; /** * 当项目启动后执行run方法。 */ @Component public class MyApplicationRunner implements ApplicationRunner { @Override public void run(ApplicationArguments args) throws Exception { System.out.println("ApplicationRunner...run"); System.out.println(Arrays.asList(args.getSourceArgs())); } }
CommandLineRunner使用案例:#
package com.itheima.springbootlistener.listener; import org.springframework.boot.CommandLineRunner; import org.springframework.stereotype.Component; import java.util.Arrays; /** * 当项目启动后执行run方法。 */ @Component public class MyCommandLineRunner implements CommandLineRunner { @Override public void run(String... args) throws Exception { System.out.println("CommandLineRunner...run"); System.out.println(Arrays.asList(args)); } }
ApplicationContextInitializer使用案例:#
需要在src/main/resources/META-INF/spring.factories中指定:
org.springframework.context.ApplicationContextInitializer=com.itheima.springbootlistener.listener.MyApplicationContextInitializer
package com.itheima.springbootlistener.listener; import org.springframework.context.ApplicationContextInitializer; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.stereotype.Component; /** * 当IOC容器初始化之前,可用于检测一些资源是否存在。 */ @Component public class MyApplicationContextInitializer implements ApplicationContextInitializer { @Override public void initialize(ConfigurableApplicationContext applicationContext) { System.out.println("ApplicationContextInitializer....initialize"); } }
SpringApplicationRunListener使用案例:#
需要在src/main/resources/META-INF/spring.factories中指定:
org.springframework.boot.SpringApplicationRunListener=com.itheima.springbootlistener.listener.MySpringApplicationRunListener
且必须有带参构造方法:
public MySpringApplicationRunListener(SpringApplication application, String[] args) {}
package com.itheima.springbootlistener.listener; import org.springframework.boot.SpringApplication; import org.springframework.boot.SpringApplicationRunListener; import org.springframework.context.ConfigurableApplicationContext; import org.springframework.core.env.ConfigurableEnvironment; import org.springframework.stereotype.Component; public class MySpringApplicationRunListener implements SpringApplicationRunListener { public MySpringApplicationRunListener(SpringApplication application, String[] args) { } @Override public void starting() { System.out.println("starting...项目启动中"); } @Override public void environmentPrepared(ConfigurableEnvironment environment) { System.out.println("environmentPrepared...环境对象开始准备"); } @Override public void contextPrepared(ConfigurableApplicationContext context) { System.out.println("contextPrepared...上下文对象开始准备"); } @Override public void contextLoaded(ConfigurableApplicationContext context) { System.out.println("contextLoaded...上下文对象开始加载"); } @Override public void started(ConfigurableApplicationContext context) { System.out.println("started...上下文对象加载完成"); } @Override public void running(ConfigurableApplicationContext context) { System.out.println("running...项目启动完成,开始运行"); } @Override public void failed(ConfigurableApplicationContext context, Throwable exception) { System.out.println("failed...项目启动失败"); } }
执行的生命周期:#
com.itheima.springbootlistener.SpringbootListenerApplication starting...项目启动中 environmentPrepared...环境对象开始准备 .----------------. .----------------. .----------------. | .--------------. || .--------------. || .--------------. | | | ____ ____ | || | ____ ____ | || | _____ | | | | |_ _||_ _| | || | |_ _||_ _| | || | |_ _| | | | | \ \ / / | || | \ \ / / | || | | | | | | | \ \/ / | || | \ \/ / | || | _ | | | | | | _| |_ | || | _| |_ | || | | |_' | | | | | |______| | || | |______| | || | `.___.' | | | | | || | | || | | | | '--------------' || '--------------' || '--------------' | '----------------' '----------------' '----------------' ApplicationContextInitializer....initialize contextPrepared...上下文对象开始准备 2023-02-12 00:05:53.758 INFO 3428 --- [ main] c.i.s.SpringbootListenerApplication : Starting SpringbootListenerApplication on DESKTOP-827ESQR with PID 3428 (D:\IdeaProjects\springboot-demo\springboot02\springboot-listener\target\classes started by yyj in D:\IdeaProjects\springboot-demo\springboot02) 2023-02-12 00:05:53.760 INFO 3428 --- [ main] c.i.s.SpringbootListenerApplication : No active profile set, falling back to default profiles: default contextLoaded...上下文对象开始加载 2023-02-12 00:05:54.049 INFO 3428 --- [ main] c.i.s.SpringbootListenerApplication : Started SpringbootListenerApplication in 0.453 seconds (JVM running for 0.778) started...上下文对象加载完成 ApplicationRunner...run [] CommandLineRunner...run [] running...项目启动完成,开始运行 Process finished with exit code 0
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)