@EventListener注解
@Target({
ElementType.METHOD, ElementType.ANNOTATION_TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface EventListener {
@AliasFor("classes") Class<?>[] value() default {
};
@AliasFor("value") Class<?>[] classes() default {
};
String condition() default "";
}
用法
- 使用value或者classes指定需要监听的事件类型;
- 如果只需要监听一种类型参数,则直接在此注解标注的方法参数上写处理的事件类型参数即可;
- 如果该注解标注的方法的返回值不是void,则会将返回值作为事件,继续发布,如果是数组或集合则分开发布;
- 该注解可以配合@Order注解一块使用来指定监听方法执行的顺序
- condition中可以写SpEL表达式,#root.event可以引用事件对象,#root.args可以引用方法参数
@EventListener注解使用示例
@Configuration
public class ListenerConfig {
// 如果不写classes,则会监听到 ContextRefreshedEvent、ServletWebServerInitializedEvent、ApplicationStartedEvent、ApplicationReadyEvent
// 如下写了classes后,则只会监听到ApplicationStartedEvent事件了,后面的condition是可以使用SpEL表达式作为过滤条件的
@EventListener/*(classes = {ApplicationStartedEvent.class},condition = "#root.event.timestamp>0")*/
public ApplicationEvent handApplicationEvent(ApplicationStartedEvent event) {
System.out.println("处理事件..." + event);
return new PayloadApplicationEvent(new Object(),new Object()); // 返回值若不为null,则会继续发布该事件
}
@EventListener/*(classes = {ApplicationStartedEvent.class},condition = "#root.event.timestamp>0")*/
public void handPayloadApplicationEvent(PayloadApplicationEvent event) {
System.out.println("处理事件...2" + event);
}
}
今天的文章@EventListener注解的使用分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/27977.html