SpringBoot事件監(jiān)聽的4種實(shí)現(xiàn)方式
springboot進(jìn)行事件監(jiān)聽有四種方式:
1.手工向ApplicationContext中添加監(jiān)聽器
2.將監(jiān)聽器裝載入spring容器
3.在application.properties中配置監(jiān)聽器
4.通過(guò)@EventListener注解實(shí)現(xiàn)事件監(jiān)聽
講到事件監(jiān)聽,這里我們說(shuō)下自定義事件和自定義監(jiān)聽器類的實(shí)現(xiàn)方式:
自定義事件:繼承自ApplicationEvent抽象類,然后定義自己的構(gòu)造器
自定義監(jiān)聽:實(shí)現(xiàn)ApplicationListener
public?class?MyListener1?implements?ApplicationListener
{
?Logger?logger?=?Logger.getLogger(MyListener1.class);
?
?public?void?onApplicationEvent(MyEvent?event)
?{
??logger.info(String.format("%s監(jiān)聽到事件源:%s.",?MyListener1.class.getName(),?event.getSource()));
?}
}
@SpringBootApplication
public?class?LisenterApplication
{
?public?static?void?main(String[]?args)
?{
??ConfigurableApplicationContext?context?=?SpringApplication.run(LisenterApplication.class,?args);
??//裝載監(jiān)聽
??context.addApplicationListener(new?MyListener1());
?}
}
方式2.
@Component
public?class?MyListener2?implements?ApplicationListener
{
?Logger?logger?=?Logger.getLogger(MyListener2.class);
?
?public?void?onApplicationEvent(MyEvent?event)
?{
??logger.info(String.format("%s監(jiān)聽到事件源:%s.",?MyListener2.class.getName(),?event.getSource()));
?}
}
方式3.
public?class?MyListener3?implements?ApplicationListener
{
?Logger?logger?=?Logger.getLogger(MyListener3.class);
?
?public?void?onApplicationEvent(MyEvent?event)
?{
??logger.info(String.format("%s監(jiān)聽到事件源:%s.",?MyListener3.class.getName(),?event.getSource()));
?}
}
context.listener.classes=com.listener.MyListener3
方式4.
@Component
public?class?MyListener4
{
?Logger?logger?=?Logger.getLogger(MyListener4.class);
?
?@EventListener
?public?void?listener(MyEvent?event)
?{
??logger.info(String.format("%s監(jiān)聽到事件源:%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());
??//發(fā)布事件
??context.publishEvent(new?MyEvent("測(cè)試事件."));
?}
}
2018-06-15 10:51:20.198 INFO 4628 ---?[?????????? main] com.listener.MyListener3 ????????????????: com.listener.MyListener3監(jiān)聽到事件源:測(cè)試事件..
2018-06-15 10:51:20.198 INFO 4628 ---?[?????????? main] com.listener.MyListener4 ????????????????: com.listener.MyListener4監(jiān)聽到事件源:測(cè)試事件..
2018-06-15 10:51:20.199 INFO 4628 ---?[?????????? main] com.listener.MyListener2 ????????????????: com.listener.MyListener2監(jiān)聽到事件源:測(cè)試事件..
2018-06-15 10:51:20.199 INFO 4628 ---?[?????????? main] com.listener.MyListener1 ????????????????: com.listener.MyListener1監(jiān)聽到事件源:測(cè)試事件..
評(píng)論
圖片
表情
