springboot进行事件监听有四种形式:

手工向ApplicationContext中增加监听器

将监听器装载入spring容器

在application.properties中配置监听器

通过@EventListener注解实现事件监听

讲到事件监听,这里咱们说下自定义事件和自定义监听器类的实现形式:

自定义事件:继承自ApplicationEvent抽象类,而后定义本人的结构器

自定义监听:实现ApplicationListener<T>接口,而后实现onApplicationEvent办法
上面讲下4种事件监听的具体实现.

形式1

首先创立MyListener1类

public class MyListener1 implements ApplicationListener<MyEvent>{ Logger logger = Logger.getLogger(MyListener1.class);  public void onApplicationEvent(MyEvent event) {  logger.info(String.format("%s监听到事件源:%s.", MyListener1.class.getName(), event.getSource())); }}

而后在springboot利用启动类中获取ConfigurableApplicationContext上下文,装载监听

@SpringBootApplicationpublic class LisenterApplication{ public static void main(String[] args) {  ConfigurableApplicationContext context = SpringApplication.run(LisenterApplication.class, args);  //装载监听  context.addApplicationListener(new MyListener1()); }}

形式2

创立MyListener2类,并应用@Component注解将该类装载入spring容器中

@Componentpublic class MyListener2 implements ApplicationListener<MyEvent>{ Logger logger = Logger.getLogger(MyListener2.class);  public void onApplicationEvent(MyEvent event) {  logger.info(String.format("%s监听到事件源:%s.", MyListener2.class.getName(), event.getSource())); }}

形式3

首先创立MyListener3类

public class MyListener3 implements ApplicationListener<MyEvent>{ Logger logger = Logger.getLogger(MyListener3.class);  public void onApplicationEvent(MyEvent event) {  logger.info(String.format("%s监听到事件源:%s.", MyListener3.class.getName(), event.getSource())); }}

而后在application.properties中配置监听

context.listener.classes=com.listener.MyListener3

形式4

创立MyListener4类,java培训该类无需实现ApplicationListener接口,应用@EventListener装璜具体方法

@Componentpublic class MyListener4{ Logger logger = Logger.getLogger(MyListener4.class);  @EventListener public void listener(MyEvent event) {  logger.info(String.format("%s监听到事件源:%s.", MyListener4.class.getName(), event.getSource())); }}

自定义事件代码如下:

@SuppressWarnings("serial")public class MyEvent extends ApplicationEvent{ public MyEvent(Object source) {  super(source); }}

进行测试(在启动类中退出公布事件的逻辑):

@SpringBootApplicationpublic class LisenterApplication{ public static void main(String[] args) {  ConfigurableApplicationContext context = SpringApplication.run(LisenterApplication.class, args);  //装载事件  context.addApplicationListener(new MyListener1());  //公布事件  context.publishEvent(new MyEvent("测试事件.")); }}

启动后,日志打印如下:

2018-06-15 10:51:20.198  INFO 4628 --- [           main] com.listener.MyListener3                 : com.listener.MyListener3监听到事件源:测试事件..2018-06-15 10:51:20.198  INFO 4628 --- [           main] com.listener.MyListener4                 : com.listener.MyListener4监听到事件源:测试事件..2018-06-15 10:51:20.199  INFO 4628 --- [           main] com.listener.MyListener2                 : com.listener.MyListener2监听到事件源:测试事件..2018-06-15 10:51:20.199  INFO 4628 --- [           main] com.listener.MyListener1                 : com.listener.MyListener1监听到事件源:测试事件..

由日志打印能够看出,SpringBoot四种事件的实现形式监听是有序的