共计 2637 个字符,预计需要花费 7 分钟才能阅读完成。
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 上下文,装载监听
@SpringBootApplication
public class LisenterApplication
{public static void main(String[] args)
{ConfigurableApplicationContext context = SpringApplication.run(LisenterApplication.class, args);
// 装载监听
context.addApplicationListener(new MyListener1());
}
}
形式 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()));
}
}
形式 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 装璜具体方法
@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 四种事件的实现形式监听是有序的
正文完