当前位置: 首页 > news >正文

java springboot监听事件和处理事件

在Spring Boot中,监听和处理事件是一种常用的模式,用于在应用程序的不同部分之间传递信息。Spring 的事件发布/订阅模型允许我们创建自定义事件,并在这些事件发生时由注册的监听器进行处理。这里,我将提供一个简单的Spring Boot应用程序示例,其中将包括事件的定义、事件的发布以及事件的监听。

1. Spring Boot应用程序示例

1.1 步骤 1: 创建Spring Boot项目

首先,我们可以使用Spring Initializr(https://start.spring.io/)来快速生成一个新的Spring Boot项目。在项目中添加Spring Web依赖,因为我们将使用一个简单的REST API来触发事件发布。

1.2 步骤 2: 定义事件

首先,我们定义一个简单的事件类。这个类将作为事件对象在应用程序中传递。

import org.springframework.context.ApplicationEvent;  public class CustomEvent extends ApplicationEvent {  private final String message;  public CustomEvent(Object source, String message) {  super(source);  this.message = message;  }  public String getMessage() {  return message;  }  
}

1.3 步骤 3: 创建事件监听器

然后,我们定义一个监听器来监听上面定义的事件。

import org.springframework.context.event.EventListener;  
import org.springframework.stereotype.Component;  @Component  
public class CustomEventListener {  @EventListener  public void handleCustomEvent(CustomEvent event) {  System.out.println("Received custom event - " + event.getMessage());  // 在这里可以执行更多操作,比如发送邮件、更新数据库等  }  
}

1.4 步骤 4: 发布事件

现在,我们需要一个方式来发布事件。通常,这会在业务逻辑代码中完成,但为了简单起见,我们将通过REST API来触发事件的发布。

首先,在我们的Spring Boot应用中添加一个控制器。

import org.springframework.beans.factory.annotation.Autowired;  
import org.springframework.context.ApplicationEventPublisher;  
import org.springframework.web.bind.annotation.PostMapping;  
import org.springframework.web.bind.annotation.RequestParam;  
import org.springframework.web.bind.annotation.RestController;  @RestController  
public class EventController {  @Autowired  private ApplicationEventPublisher eventPublisher;  @PostMapping("/publish")  public String publishEvent(@RequestParam String message) {  CustomEvent customEvent = new CustomEvent(this, message);  eventPublisher.publishEvent(customEvent);  return "Event published with message: " + message;  }  
}

1.5 步骤 5: 运行我们的Spring Boot应用

现在,我们可以运行我们的Spring Boot应用。一旦应用启动,我们可以使用Postman或curl命令来触发事件发布。

bash复制代码
​
curl -X POST http://localhost:8080/publish?message=Hello%20Spring%20Events

我们将在控制台看到输出,表明CustomEventListener已经接收并处理了事件。

1.6 总结

以上就是在Spring Boot中监听和处理自定义事件的一个完整示例。通过定义事件、创建监听器并发布事件,我们可以在不同的组件或服务之间轻松地传递信息。这种模式在微服务架构中尤其有用,因为它支持松耦合的通信方式。

2. 更详细的Spring Boot代码示例

当然,我会给出一个更详细的Spring Boot代码示例,该示例包含了完整的项目结构、配置以及必要的类来展示如何定义事件、监听事件以及通过REST API发布事件。

2.1 项目结构

假设我们的项目结构如下:

src/  
|-- main/  
|   |-- java/  
|   |   |-- com/  
|   |   |   |-- example/  
|   |   |       |-- demo/  
|   |   |           |-- DemoApplication.java  
|   |   |           |-- CustomEvent.java  
|   |   |           |-- CustomEventListener.java  
|   |   |           |-- EventController.java  
|   |-- resources/  
|       |-- application.properties  
|  
|-- pom.xml

2.2 pom.xml

首先,确保我们的pom.xml文件中包含了Spring Boot的起步依赖(starter)和Spring Web依赖:

<dependencies>  <dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-web</artifactId>  </dependency>  <!-- Optional, but recommended -->  <dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-test</artifactId>  <scope>test</scope>  </dependency>  
</dependencies>  <properties>  <java.version>11</java.version>  <spring-boot.version>2.5.4</spring-boot.version>  
</properties>  <parent>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-parent</artifactId>  <version>${spring-boot.version}</version>  
</parent>

2.3 DemoApplication.java

这是Spring Boot的主应用类:

package com.example.demo;  import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;  @SpringBootApplication  
public class DemoApplication {  public static void main(String[] args) {  SpringApplication.run(DemoApplication.class, args);  }  
}

2.4 CustomEvent.java

这是自定义事件类:

package com.example.demo;  import org.springframework.context.ApplicationEvent;  public class CustomEvent extends ApplicationEvent {  private final String message;  public CustomEvent(Object source, String message) {  super(source);  this.message = message;  }  public String getMessage() {  return message;  }  
}

2.5 CustomEventListener.java

这是事件监听器类:

package com.example.demo;  import org.springframework.context.event.EventListener;  
import org.springframework.stereotype.Component;  @Component  
public class CustomEventListener {  @EventListener  public void handleCustomEvent(CustomEvent event) {  System.out.println("Received custom event - " + event.getMessage());  // 在这里可以执行更多操作,比如发送邮件、更新数据库等  }  
}

2.6 EventController.java

这是REST控制器类,用于发布事件:

package com.example.demo;  import org.springframework.beans.factory.annotation.Autowired;  
import org.springframework.context.ApplicationEventPublisher;  
import org.springframework.web.bind.annotation.PostMapping;  
import org.springframework.web.bind.annotation.RequestParam;  
import org.springframework.web.bind.annotation.RestController;  @RestController  
public class EventController {  @Autowired  private ApplicationEventPublisher eventPublisher;  @PostMapping("/publish")  public String publishEvent(@RequestParam String message) {  CustomEvent customEvent = new CustomEvent(this, message);  eventPublisher.publishEvent(customEvent);  return "Event published with message: " + message;  }  
}

2.7 application.properties

这是一个空的application.properties文件,但我们可以在这里添加任何Spring Boot配置。

2.8 运行和测试

(1)运行DemoApplication.java来启动Spring Boot应用。

(2)使用Postman或curl命令向http://localhost:8080/publish?message=Hello%20Spring%20Events发送POST请求。

(3)查看控制台输出,当我们向/publish端点发送POST请求时,Spring Boot应用会捕获到这个请求,并通过EventController中的publishEvent方法发布一个CustomEvent。这个事件随后被CustomEventListener捕获并处理,我们会在控制台上看到类似这样的输出:

复制代码
​
Received custom event - Hello Spring Events

这表明我们的事件监听器成功接收到了事件,并执行了相应的逻辑(在这个例子中是打印了一条消息)。

2.9 完整测试

为了完整地测试这个功能,我们可以使用Postman或者curl命令行工具来发送HTTP POST请求。以下是使用curl命令的示例:

bash复制代码
​
curl -X POST http://localhost:8080/publish?message=Hello%20Spring%20Events

我们应该会收到一个响应,内容是:

复制代码
​
Event published with message: Hello Spring Events

同时,我们的Spring Boot应用的控制台上也会显示事件被接收的消息。

2.10 总结

这个示例展示了如何在Spring Boot应用中定义自定义事件、发布事件以及监听事件。这是Spring事件驱动编程模型的一个简单应用,它允许我们以解耦的方式在应用的不同部分之间传递信息。在这个例子中,我们创建了一个简单的REST API来触发事件的发布,但这只是事件发布方式的一种。在更复杂的应用中,事件可能由多种不同的源触发,包括其他REST API调用、数据库更新、定时任务等。

通过利用Spring的事件监听和发布机制,我们可以轻松地构建出更加模块化和可维护的应用,因为我们可以在不修改监听器代码的情况下添加新的事件源,或者在不修改事件源代码的情况下添加新的监听器。这种解耦的方式使得应用更加灵活和可扩展。

相关文章:

  • C#委托事件的实现
  • RNN文献综述
  • CC2530寄存器编程学习笔记_点灯
  • C编程使用clock函数实现计算一段代码的执行时间:毫秒单位
  • 17.分频器设计拓展练习-任意分频通用模块
  • XML Schema 属性
  • 揭秘:离心风机风量背后的科学原理
  • 没什么事情,随记一下 -出差
  • Labview_压缩文件
  • 关于string的‘\0‘与string,vector构造特点加部分特别知识点的讨论
  • 详细对比Java SPI、Spring SPI 和 Dubbo SPI
  • 【机器学习】特征选择:精炼数据,提升模型效能
  • 暴雨突袭不可不看!水浸传感器作用有这些
  • ubuntu 查看联网配置
  • PaddleVideo:Squeeze Time算法移植
  • 【159天】尚学堂高琪Java300集视频精华笔记(128)
  • 【译】React性能工程(下) -- 深入研究React性能调试
  • gf框架之分页模块(五) - 自定义分页
  • JavaScript DOM 10 - 滚动
  • JavaScript服务器推送技术之 WebSocket
  • leetcode388. Longest Absolute File Path
  • Markdown 语法简单说明
  • OpenStack安装流程(juno版)- 添加网络服务(neutron)- controller节点
  • Promise面试题,控制异步流程
  • Python中eval与exec的使用及区别
  • quasar-framework cnodejs社区
  • SpiderData 2019年2月13日 DApp数据排行榜
  • Synchronized 关键字使用、底层原理、JDK1.6 之后的底层优化以及 和ReenTrantLock 的对比...
  • vue数据传递--我有特殊的实现技巧
  • Vue--数据传输
  • 对超线程几个不同角度的解释
  • 二维平面内的碰撞检测【一】
  • 复杂数据处理
  • 观察者模式实现非直接耦合
  • 回顾 Swift 多平台移植进度 #2
  • 机器学习中为什么要做归一化normalization
  • 看图轻松理解数据结构与算法系列(基于数组的栈)
  • 理解IaaS, PaaS, SaaS等云模型 (Cloud Models)
  • 入门到放弃node系列之Hello Word篇
  • 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  • ​【经验分享】微机原理、指令判断、判断指令是否正确判断指令是否正确​
  • ​LeetCode解法汇总2583. 二叉树中的第 K 大层和
  • ​LeetCode解法汇总2696. 删除子串后的字符串最小长度
  • ​卜东波研究员:高观点下的少儿计算思维
  • # AI产品经理的自我修养:既懂用户,更懂技术!
  • #HarmonyOS:软件安装window和mac预览Hello World
  • #Linux杂记--将Python3的源码编译为.so文件方法与Linux环境下的交叉编译方法
  • #我与Java虚拟机的故事#连载10: 如何在阿里、腾讯、百度、及字节跳动等公司面试中脱颖而出...
  • $redis-setphp_redis Set命令,php操作Redis Set函数介绍
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (2)MFC+openGL单文档框架glFrame
  • (4)STL算法之比较
  • (9)目标检测_SSD的原理
  • (C#)获取字符编码的类
  • (C语言)二分查找 超详细