JAVA:Springboot 集成 WebSocket 和 STOMP 实时消息的技术指南

1、简述

随着互联网应用的复杂性和实时性需求的增加,传统的 HTTP 请求响应模式已不能满足某些场景的需求。WebSocket 和 STOMP 协议为构建实时消息传输提供了极大的便利。本文将介绍如何在 Spring Boot 中使用 WebSocket 和 STOMP 创建一个实时消息应用,并通过实例展示其实现过程。

在这里插入图片描述

2、工作原理

2.1 WebSocket

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。与传统的 HTTP 不同,WebSocket 在客户端与服务器之间建立连接后,可以在不关闭连接的情况下,进行双向数据传输。这使得 WebSocket 成为实现实时应用程序(如聊天应用、实时通知等)的理想选择。

2.2 STOMP

STOMP(Simple/Streaming Text Oriented Messaging Protocol)是一个简单的消息传递协议,通常用于 WebSocket 上层,以实现基于消息的通信。STOMP 协议定义了如何订阅主题、发送消息等操作,非常适合在 WebSocket 环境中使用。

2.3 WebSocket 和 STOMP 的工作原理
  • 客户端建立 WebSocket 连接:客户端通过 WebSocket 连接到服务器,并订阅感兴趣的主题(topics)。
  • 消息发布与订阅:当服务器有新的消息时,会根据消息主题将消息推送给订阅该主题的客户端。
  • 双向通信:WebSocket 允许服务器和客户端之间进行双向通信,客户端也可以通过 WebSocket 发送消息到服务器。
    在这里插入图片描述

3、集成

3.1 引入依赖

在 Spring Boot 项目中使用 WebSocket 和 STOMP,首先需要在 pom.xml 中添加相关依赖:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
3.2 配置 WebSocket 和 STOMP

接下来,需要创建 WebSocket 配置类,启用 STOMP 消息代理:

import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;
import org.springframework.web.socket.config.annotation.WebSocketMessageBrokerConfigurer;@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {@Overridepublic void configureMessageBroker(MessageBrokerRegistry config) {config.enableSimpleBroker("/topic");  // 主题路径前缀config.setApplicationDestinationPrefixes("/app");  // 应用路径前缀}@Overridepublic void registerStompEndpoints(StompEndpointRegistry registry) {registry.addEndpoint("/ws").withSockJS();  // WebSocket 连接路径}
}

在这个配置中,/topic 表示消息主题的路径前缀,/app 表示应用消息发送路径前缀,/ws 则是 WebSocket 连接的端点。

3.3 创建消息处理器

接下来,我们需要创建一个消息处理器类,用于接收和处理来自客户端的消息:

import org.springframework.messaging.handler.annotation.MessageMapping;
import org.springframework.messaging.handler.annotation.SendTo;
import org.springframework.stereotype.Controller;@Controller
public class MessageController {@MessageMapping("/sendMessage")  // 接收客户端消息@SendTo("/topic/messages")  // 广播到主题public Message send(Message message) {// 处理消息的逻辑return message;  // 返回的消息将广播到所有订阅者}
}

这里的 @MessageMapping(“/sendMessage”) 表示接收客户端发送到 /app/sendMessage 的消息,并将处理后的消息广播到 /topic/messages 主题上,所有订阅了该主题的客户端将收到消息。

3.4 创建消息模型

定义一个简单的消息模型类,用于传递消息数据:

import lombok.Data;@Data
public class Message {private String from;private String text;// Getters and Setters
}
3.5 编写前端代码

在前端(如使用 JavaScript)中,可以使用 SockJS 和 Stomp.js 来连接 WebSocket 并订阅消息:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>WebSocket Demo</title><script src="https://cdn.jsdelivr.net/npm/sockjs-client@1.5.1/dist/sockjs.min.js"></script><script src="https://cdn.jsdelivr.net/npm/stompjs@2.3.3/lib/stomp.min.js"></script>
</head>
<body><div id="chat"><input type="text" id="message" placeholder="Enter your message"/><button onclick="sendMessage()">Send</button><ul id="messages"></ul></div><script type="text/javascript">var stompClient = null;function connect() {var socket = new SockJS('/ws');stompClient = Stomp.over(socket);stompClient.connect({}, function (frame) {console.log('Connected: ' + frame);stompClient.subscribe('/topic/messages', function (message) {showMessage(JSON.parse(message.body));});});}function sendMessage() {var messageContent = document.getElementById("message").value;stompClient.send("/app/sendMessage", {}, JSON.stringify({'text': messageContent, 'from': 'User'}));}function showMessage(message) {var messages = document.getElementById("messages");var messageElement = document.createElement('li');messageElement.appendChild(document.createTextNode(message.from + ": " + message.text));messages.appendChild(messageElement);}connect();</script>
</body>
</html>

在这个示例中,用户可以输入消息并通过 WebSocket 发送到服务器,服务器处理后再将消息广播到所有订阅该主题的客户端。

4、扩展功能

  • 私信功能:可以通过实现点对点消息发送,利用 STOMP 的 /user 目标。
  • 在线用户列表:通过 WebSocket 连接与断开时的事件处理,可以实时显示当前在线的用户列表。
  • 消息持久化:将消息保存到数据库中,实现聊天记录的持久化。

5、总结

本文详细介绍了如何在 Spring Boot 项目中集成 WebSocket 和 STOMP,构建一个简单的实时消息应用。通过 WebSocket 的双向通信能力和 STOMP 协议的消息传递机制,可以轻松实现各种实时功能,如聊天室、实时通知系统等。

实时消息传输是现代互联网应用的重要特性,了解并掌握 WebSocket 和 STOMP 能帮助你在项目中实现更高效的实时通信功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/61660.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue3+ant design vue实现日期选择器默认显示当前年,并限制用户只能选择当前年及之前~

1、思路&#xff1a;之前想拿当前年直接做赋值操作&#xff0c;实际上是行不通的&#xff0c;因为组件本身有数据格式限制&#xff0c;会出现报错&#xff0c;然后索性直接获取当前日期&#xff08;YYYY-MM-DD&#xff09;赋值给日期组件&#xff0c;这样不管你用的是年&#x…

Vue.js 中的事件处理

在 Vue.js 中&#xff0c;事件处理是用户与应用交互的重要方式。Vue.js 允许开发者以一种声明式的方式来绑定事件监听器&#xff0c;这使得代码更加简洁和易于维护。本文将介绍 Vue.js 中的事件处理&#xff0c;包括常用的事件类型和如何使用它们。 Vue.js 事件基础 在 Vue.j…

Kafka2.2.0集群安装

Kafka2.2.0 三节点集群搭建 Kafka2.2.0 基于zookeeper搭建&#xff0c;这里也搭建一个三个节点的集群。(在一个节点模拟三节点&#xff0c;真实的三节点把ip替换一下即可&#xff0c;按照hadoop案件把网络打通即可) 1、下载解压 Kafka 安装包官方下载地址 &#xff0c;本用例…

Vue文字转语音实现

在开发流程中&#xff0c;面对语音支持的需求&#xff0c;小规模语音内容或许可以通过预处理后播放来轻松应对&#xff0c;但当涉及大量语音时&#xff0c;这一方法就显得繁琐低效了。为此&#xff0c;智慧的开发者们总能找到便捷的解决方案——利用Web技术实现语音播放&#x…

AD软件如何快速切换三维视图,由2D切换至3D,以及如何恢复

在Altium Designer软件中&#xff0c;切换三维视图以及恢复二维视图的操作相对简单。以下是具体的步骤&#xff1a; 切换三维视图 在PCB设计界面中&#xff0c;2D切换3D&#xff0c;快捷键按住数字键盘中的“3”即可切换&#xff1b; 快捷键ctrlf&#xff08;或者vb快捷键也…

人工智能-卷积神经网络(学习向)

一.概述&#xff1b; 卷积神经网络&#xff08;Convolutional Neural Network, CNN&#xff09;是一种专门用于处理具有类似网格结构的数据&#xff08;如图像&#xff09;的深度学习模型。 主要用于处理机器视觉任务。 主要功能&#xff1b; 1.图像分类 2.目标检测 3.图像分割…

ABE 中的隐藏属性:DIPPE(去中心化内积谓词加密)

1. 引言 相关论文有&#xff1a; Yan Michalevsky 和 Marc Joye 2018年论文 Decentralized policy-hiding ABE with receiver privacy&#xff0c;发表于23rd European Symposium on Research in Computer Security, ESORICS 2018。Amit Sahai 和 Brent Waters 2005年论文 Fu…

深入了解阿里云 OSS:强大的云存储解决方案

在现代互联网应用中&#xff0c;数据存储是一个不可忽视的环节。随着数据量的不断增长&#xff0c;传统的存储方式已经无法满足高速、低成本、大容量的需求。阿里云 OSS&#xff08;对象存储服务&#xff09;作为一种高性能、低成本且具备高度扩展性的云存储服务&#xff0c;已…

vue和react的diff算法区别?

Vue和React都使用了虚拟DOM和diff算法来优化渲染性能。但是它们在diff算法的实现上有一些区别。 Vue的patch过程&#xff1a; Vue的diff算法是基于snabbdom修改而来&#xff0c;但Vue进行了优化&#xff0c;例如使用了一个队列来批处理节点的更新&#xff0c;并对不同类型的节…

书生浦语·第四期作业合集

目录 1. Linux基础知识 1.1-Linux基础知识 1.在终端通过ssh 端口映射连接开发机 2. 创建helloworld.py 3.安装相关包并运行 4.端口映射并访问相关网页

小程序-基于java+SpringBoot+Vue的校园快递平台系统设计与实现

项目运行 1.运行环境&#xff1a;最好是java jdk 1.8&#xff0c;我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境&#xff1a;IDEA&#xff0c;Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境&#xff1a;Tomcat 7.x,8.x,9.x版本均可 4.硬件环境&#xff1a…

【智商检测——DP】

题目 代码 #include <bits/stdc.h> using namespace std; const int N 1e510, M 110; int f[N][M]; int main() {int n, k;cin >> n >> k;for(int i 1; i < n; i){int x;cin >> x;f[i][0] __gcd(f[i-1][0], x);for(int j 1; j < min(i, k)…

鸿蒙面试 --- 1202 下

1、什么是层叠布局&#xff1f; 层叠布局&#xff08;StackLayout&#xff09;用于在屏幕上预留一块区域来显示组件中的元素&#xff0c;提供元素可以重叠的布局。层叠布局通过Stack容器组件实现位置的固定定位与层叠&#xff0c;容器中的子元素依次入栈&#xff0c;后一个子元…

MYSQL 什么是内连接 外连接 左连接 右连接?及适用场景

在 SQL 中&#xff0c;连接&#xff08;JOIN&#xff09;是用于组合来自两个或更多表的行的一种方法。根据连接的方式不同&#xff0c;可以分为几种类型的连接&#xff1a;内连接&#xff08;INNER JOIN&#xff09;、外连接&#xff08;OUTER JOIN&#xff09;、左连接&#x…

CTF-PWN: 全保护下格式化字符串利用 [第一届“吾杯”网络安全技能大赛 如果能重来] 赛后学习(没思路了)

通过网盘分享的文件&#xff1a;如果能重来.zip 链接: https://pan.baidu.com/s/1XKIJx32nWVcSpKiWFQGpYA?pwd1111 提取码: 1111 --来自百度网盘超级会员v2的分享漏洞分析 格式化字符串漏洞,在printf(format); __int64 sub_13D7() {char format[56]; // [rsp10h] [rbp-40h]…

速盾:高防cdn支持自定义缓存KEY前缀吗?

速盾是一家专业的高防CDN&#xff08;Content Delivery Network&#xff09;服务提供商&#xff0c;为客户提供安全可靠的内容分发服务。在讨论高防CDN支持自定义缓存KEY前缀之前&#xff0c;我们先来了解一下CDN和缓存的概念。 CDN是一种通过将内容分布到全球多个节点上&…

使用flex布局实现一行固定展示n个元素

前言&#xff1a; 最近在公司中完成小程序的UI设计稿时&#xff0c;遇到了布局一个问题&#xff1a;UI设计稿想实现的布局是这样的&#xff1a; 笔者第一反应就是使用flex中的justify-content: space-between;属性&#xff0c;但是使用之后发现&#xff0c;justify-content: …

node.js基础学习-querystring模块-查询字符串处理(三)

一、前言 querystring是 Node.js 中的一个内置模块&#xff0c;主要用于处理 URL 查询字符串。它提供了一些实用的方法来解析和格式化查询字符串&#xff0c;使得在处理 HTTP 请求中的查询参数等场景时非常方便。 还可以防止sql注入 二、解析查询字符串&#xff08;parse方法&a…

AntFlow 0.20.0版发布,增加多数据源多租户支持,进一步助力企业信息化,SAAS化

传统老牌工作流引擎比如activiti,flowable或者camunda等虽然功能强大&#xff0c;也被企业广泛采用&#xff0c;然后也存着在诸如学习曲线陡峭&#xff0c;上手难度大&#xff0c;流程设计操作需要专业人员&#xff0c;普通人无从下手等问题。。。引入工作流引擎往往需要企业储…

IDL学习笔记(一)数据类型、基础运算、控制语句

近期&#xff0c;需要用到modis数据批量预处理&#xff0c;于是重新学习idl,感谢郭师兄推荐&#xff0c;以及张洋老师的详细教导。特以此为学习笔记&#xff0c;望学有所成。 IDL学习笔记&#xff08;一&#xff09; 数据类型数据类型创建数组类型转换函数代码输出print往文件…