查看原文
其他

SpringBoot事件监听的4种实现方式

SpringForAll 2022-07-05
关注我,回复关键字“2022面经”
领取2022大厂Java后端面经

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

  1. 手工向ApplicationContext中添加监听器
  2. 将监听器装载入spring容器
  3. 在application.properties中配置监听器
  4. 通过@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上下文,装载监听

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

“ 推荐下自己做的连载多年还在继续更新的免费教程:

http://blog.didispace.com/spring-boot-learning-2x/

方式2

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

@Component
public 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()));
 }
}

“ 推荐下自己做的连载多年还在继续更新的免费教程:

http://blog.didispace.com/spring-boot-learning-2x/

方式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类,该类无需实现ApplicationListener接口,使用@EventListener装饰具体方法

@Component
public 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);
 }
}

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

@SpringBootApplication
public 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四种事件的实现方式监听是有序的

关注下方公众号,回复关键词【路径】
获取完整的代码路径

来源:blog.csdn.net/ignorewho/
article/details/80702827



END


关注下方公众号,回复【JAVA宝典】
获取最新免费Java资料大全


往期推荐

SpringBoot + Elasticsearch7.6实现简单查询及高亮分词查询

一个“扛住100亿次请求”的春晚红包系统

一个拿来即用的SpringBoot开源ERP系统,赶紧学习收藏了!

字节跳动面经总结,都是套路!(新鲜出炉)

SpringBoot启动时,这几种实现自动执行代码的方式你了解吗

对色情app渗透,我居然发现了 ....



您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存