Java SpringBoot
SpringBoot进行事件监听有四种方式:

  1. 手工向ApplicationContext中添加监听器
  2. 将监听器装载入spring容器
  3. 在application.properties中配置监听器
  4. 通过@EventListener注解实现事件监听

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

  • 自定义事件:继承自ApplicationEvent抽象类,然后定义自己的构造器
  • 自定义监听:实现ApplicationListener<T>接口,然后实现onApplicationEvent方法

下面讲下4种事件监听的具体实现

方式1

首先创建MyListener1类

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

然后在SpringBoot应用启动类中获取ConfigurableApplicationContext上下文,装载监听

  1. @SpringBootApplication
  2. public class LisenterApplication{
  3. public static void main(String[] args){
  4. ConfigurableApplicationContext context = SpringApplication.run(LisenterApplication.class, args);
  5. //装载监听
  6. context.addApplicationListener(new MyListener1());
  7. }
  8. }

方式2

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

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

方式3

首先创建MyListener3类

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

然后在application.properties中配置监听

  1. context.listener.classes=com.listener.MyListener3

方式4

创建MyListener4类,该类无需实现ApplicationListener接口,使用@EventListener装饰具体方法

  1. @Component
  2. public class MyListener4{
  3. Logger logger = Logger.getLogger(MyListener4.class);
  4. @EventListener
  5. public void listener(MyEvent event){
  6. logger.info(String.format("%s监听到事件源:%s.", MyListener4.class.getName(), event.getSource()));
  7. }
  8. }

自定义事件代码如下:

  1. @SuppressWarnings("serial")
  2. public class MyEvent extends ApplicationEvent{
  3. public MyEvent(Object source){
  4. super(source);
  5. }
  6. }

进行测试(在启动类中加入发布事件的逻辑):

  1. @SpringBootApplication
  2. public class LisenterApplication{
  3. public static void main(String[] args){
  4. ConfigurableApplicationContext context = SpringApplication.run(LisenterApplication.class, args);
  5. //装载事件
  6. context.addApplicationListener(new MyListener1());
  7. //发布事件
  8. context.publishEvent(new MyEvent("测试事件."));
  9. }
  10. }

启动后,日志打印如下:

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

由日志打印可以看出,SpringBoot四种事件的实现方式监听是有序的