@EventListener注解的使用

@EventListener注解的使用@EventListener注解使用

@EventListener注解的使用"

@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 "";
}

用法

  1. 使用value或者classes指定需要监听的事件类型;
  2. 如果只需要监听一种类型参数,则直接在此注解标注的方法参数上写处理的事件类型参数即可;
  3. 如果该注解标注的方法的返回值不是void,则会将返回值作为事件,继续发布,如果是数组或集合则分开发布;
  4. 该注解可以配合@Order注解一块使用来指定监听方法执行的顺序
  5. 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

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注