java springboot监听事件和处理事件

news/2024/7/23 11:34:41 标签: java, spring boot, spring

在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: 定义事件

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

java">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: 创建事件监听器

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

java">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应用中添加一个控制器。

java">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的主应用类:

java">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

这是自定义事件类:

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

这是事件监听器类:

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控制器类,用于发布事件:

java">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捕获并处理,我们会在控制台上看到类似这样的输出:

java">复制代码
​
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的事件监听和发布机制,我们可以轻松地构建出更加模块化和可维护的应用,因为我们可以在不修改监听器代码的情况下添加新的事件源,或者在不修改事件源代码的情况下添加新的监听器。这种解耦的方式使得应用更加灵活和可扩展。


http://www.niftyadmin.cn/n/5546403.html

相关文章

如何解决群晖Docker注册表查询失败/无法拉取镜像等问题

文章目录 📖 介绍 📖🏡 演示环境 🏡📒 问题概述 📒📒 解决方案 📒🔖 方法一🔖 方法二🔖 方法三⚓️ 相关链接 🚓️📖 介绍 📖 在群晖(Synology)NAS设备上使用Docker时,我们可能会遇到查询Docker注册表失败,无法拉取Docker镜像的问题。这种情况…

【Dell R730 折腾记录】风扇调速--在 Ubuntu 系统上开机自启动并每隔30分钟执行一次风扇定速脚本

前段时间升级了一下机柜里的服务器&#xff0c;替换掉了一台旧的 Dell 服务器&#xff0c;换上了这台 R730。但是无奈于噪音的袭扰&#xff0c;搁置了一段时间。我在这台机器上目前安装了一块 Intel Xeon E5-2630v3 芯片以及一张改过散热的 NVIDIA Tesla P4 计算卡。结果就是散…

Michael.W基于Foundry精读Openzeppelin第63期——Initializable.sol

Michael.W基于Foundry精读Openzeppelin第63期——Initializable.sol 0. 版本0.1 Initializable.sol 1. 目标合约2. 代码精读2.1 _getInitializedVersion() internal && _isInitializing() internal2.2 modifier initializer()2.3 modifier reinitializer(uint8 version…

C++-时间复杂度

前言 OJ测试中最烦人的结果莫过于TLE(Time Limit Exceed 超时)和MLE(Mempry Limit Exceed超内存&#xff09;了&#xff0c;在递归和搜索题里面看见这两货就烦。 目录 前言 时间复杂度 时间复杂度概念 时间复杂度的表示法 时间复杂度OJ测试要求 时间复杂度例举 剪枝 1.可行…

uniapp本地打包到Android Studio生成APK文件

&#xff08;1&#xff09;安装 Android Studio 软件&#xff1b; 下载地址&#xff1a;官方下载地址&#xff0c;英文环境 安装&#xff1a;如下之外&#xff0c;其他一键 next &#xff08;2&#xff09;配置java环境&#xff1b; 下载&#xff1a;j…

deepstream段错误

&#x1f610; 错误&#xff1a; 探针中由于使用了pyds.get_nvds_buf_surface(hash(gst_buffer), frame_meta.batch_id)导致的段错误&#xff08;segmentation fault&#xff09;。 解决方式&#xff1a;

每日一练 - RSTP响应端口故障后的处理流程

01 真题题目 在如图所示的网络中&#xff0c; 所有的交换机运行 RSTP 协议&#xff0c; 假如 SWB 的 E 1 接口故障后&#xff0c; RSTP 的处理过程是&#xff1a;(多选) A.SWB 删除 MAC 地址表中以 E 1 为目的端口的端口表项。 B.重新计算生成树&#xff0c;选举 E2 为新的根…

JavaScript---new Map()用法

new Map 创建 Map 对象设置键值对获取值检查键是否存在键值对数量删除键值对清空所有键值对迭代 Map 在JavaScript中&#xff0c;Map 是一个构造函数&#xff0c;用于创建 Map 对象&#xff0c;它可以存储键值对集合。与普通的对象不同&#xff0c;Map 的键可以是任何类型的值&…