spring event (@EventListener)

package com.hhwy;

import org.springframework.context.ApplicationEvent;

public class DemoEvent extends ApplicationEvent{

    private String msg;

    private String email;

    public DemoEvent(Object source,String msg,String email) {
        super(source);
        this.msg=msg;
        this.email=email;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

}
package com.hhwy.fm.projectmonthlyreport;

import com.hhwy.DemoEvent;
import org.springframework.context.ApplicationListener;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;

/**
 * <br>描 述:
 * <br>创 建 人:jzq
 * <br>创建时间:2019/6/3 19:48
 * <br>修改备注:无
 * <br>版本:1.0.0
 */
@Component
public class DemoEventListener implements ApplicationListener<DemoEvent> {

    //使用注解@Async支持 这样不仅可以支持通过调用,也支持异步调用,非常的灵活,
    @Async
    @Override
    public void onApplicationEvent(DemoEvent event) {
        System.out.println("注册成功,发送确认邮件为:" + event.getEmail()+",消息摘要为:"+event.getMsg());
    }

}
package com.hhwy.fm.projectmonthlyreport;

import com.hhwy.DemoEvent;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Component;

/**
 * <br>描 述:
 * <br>创 建 人:jzq
 * <br>创建时间:2019/6/3 19:52
 * <br>修改备注:无
 * <br>版本:1.0.0
 */
@Component
public class DemoEventPublisher {

    @Autowired
    private ApplicationContext applicationContext;

    public void pushlish(String msg,String mail){
        applicationContext.publishEvent(new DemoEvent(this, msg,mail));
    }

}
package com.hhwy.fm.projectmonthlyreport.controller;

import com.hhwy.fm.projectmonthlyreport.DemoEventPublisher;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

/**
 * <br>描 述:检测-保函管理
 * <br>创 建 人:Jinzhaoqiang
 * <br>创建时间:19.5.17 
 * <br>修改备注:无
 * <br>版本:1.0.0
 */
@RestController
@RequestMapping("/test")
public class Test {

   @Autowired
   private DemoEventPublisher demoEventPublisher;
 
   @RequestMapping(value = "/test", method = RequestMethod.GET)
   public void test() {
      demoEventPublisher.pushlish("张三1","565792147@qq.com");
      demoEventPublisher.pushlish("张三2","565792147@qq.com"); 
   }
}

转载于:https://my.oschina.net/u/2351011/blog/3057903

Spring框架提供了一系列注解用于处理事件机制,其中`@EventListener`和`@TransactionalEventListener`都是在特定场景下使用的。下面是对这两个注解的详细介绍: ### @EventListener `@EventListener`是一个用于监听特定类型的事件(例如来自`ApplicationEventPublisher`、`Message`、`ContextRefreshedEvent`等)的注解。它可以应用于方法上,当指定事件发生时,该方法会被触发执行。这是Spring事件驱动架构的基本组成部分之一。 #### 使用示例: ```java import org.springframework.context.ApplicationListener; import org.springframework.context.event.ContextRefreshedEvent; import org.springframework.stereotype.Component; @Component public class MyEventListener implements ApplicationListener<ContextRefreshedEvent> { @Override public void onApplicationEvent(ContextRefreshedEvent event) { // 在这里执行事件相关的操作 System.out.println("应用程序已经刷新并准备好接收数据"); } } ``` ### @TransactionalEventListener `@TransactionalEventListener`与`@EventListener`类似,但是它还增加了事务管理的功能。这个注解允许你在监听事件的同时保证交易的原子性,即要么所有的操作都成功完成,要么都不执行。 #### 主要特点: - **事务管理**:当你在一个方法中使用了`@TransactionalEventListener`,Spring将自动在这个方法运行时创建一个新的事务。如果方法正常结束,则事务提交;如果方法抛出异常,则事务回滚。 - **易于整合**:这种方式简化了在处理事件时需要手动管理事务的过程,使得应用在处理异步事件时仍能保持一致性。 #### 使用示例: ```java import org.springframework.transaction.annotation.Transactional; import org.springframework.context.event.EventListener; import org.springframework.stereotype.Component; @Component public class TransactionalEventListener { @EventListener @Transactional public void handleEvent(MyCustomEvent event) { // 这里执行事件处理,并假设存在一些业务逻辑操作 System.out.println("处理自定义事件:" + event.getMessage()); } } ``` 注意:这里的`MyCustomEvent`应该是实际自定义事件的类实例。 ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值