Spring事件
1、關鍵類:
ApplicationEvent:事件源
ApplicationListener:編碼式事件監聽及處理(業務邏輯處理)
@EventListener:註解式事件監聽及處理
ApplicationContext:spring容器,用於發佈事件
2、遵循流程:
自定義事件,繼承ApplicationEvent
定義監聽事件,實現ApplicationListener
定義消息,發到容器中,使容器觸發事件
發佈事件,使用ApplicationContext發佈事件
3、異步處理
默認Spring事件是同步處理
異步關鍵:開啓@EnableAsync;方法上添加Async
4、實例
(1)事件類
@Data
public class MessEvent extends ApplicationEvent {
private Long postId;
private Long fromUserId;
private Long toUserId;
private int type;//0:評論事件,1:其他事件
public MessEvent(Object source,int type) {
super(source);
this.type = type;
}
}
(2)事件監聽類
//主鍵注入到容器,容器才能傳播事件
@Component
@Slf4j
public class MessEventListener implements ApplicationListener<MessEvent> {
@Override
public void onApplicationEvent(MessEvent messEvent) {
//messEvent.toString()指事件的消息
System.out.println("接收到事件----" + messEvent.toString());
log.debug("接收到事件----" + messEvent.toString());//調試
}
}
(3)Spring容器發佈事件,在啓動類內添加容器
@RestController
@SpringBootApplication
public class HelloApplication {
public static void main(String[] args) {
SpringApplication.run(HelloApplication.class, args);
System.out.println("hello,舊時光!");
}
//添加容器
@Autowired
ApplicationContext applicationContext;
@GetMapping("/test")
public Object test(){
MessEvent event = new MessEvent(this,0);
event.setPostId(1L);
event.setFromUserId(99L);
applicationContext.publishEvent(event);
System.out.println("Spring事件-------");
return "你是認真的嗎?";
}
}
啓動該項目,訪問地址http://localhost:8099/test,運行結果如下所示:
修改成同步事件
(1)修改啓動類
添加註解:@Slf4j
輸出形式改成如下:
log.info("Spring事件-------test");
(2)修改監聽事件類
//System.out.println("接收到事件----" + messEvent.toString());
log.info("接收到事件----" + messEvent.toString());//調試
啓動該項目,訪問地址http://localhost:8099/test,運行結果如下所示:
修改成異步事件
(1)修改啓動類
添加註解:@EnableAsync
(2)修改監聽事件類
添加註解:
@Async
@Override
啓動該項目,訪問地址http://localhost:8099/test,運行結果如下所示: