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

springboot实现简单的消息对话

目录

一、前言

二、实战步骤

步骤 1:

步骤 2:

步骤 3:

步骤 4:


一、前言

要在Spring Boot项目中实现消息对话,你可以使用WebSocket技术。WebSocket是一种在客户端和服务器之间提供实时双向通信的协议。

二、实战步骤

步骤 1:

添加依赖 首先,在您的Spring Boot项目的pom.xml文件中添加以下依赖:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId>
</dependency>

步骤 2:

创建WebSocket配置类 接下来,创建一个配置类来配置WebSocket相关的组件。例如,创建一个名为WebSocketConfig的类,并添加以下代码:

@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {@Overridepublic void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {registry.addHandler(chatWebSocketHandler(), "/chat").setAllowedOrigins("*");}@Beanpublic WebSocketHandler chatWebSocketHandler() {return new ChatWebSocketHandler();}
}

步骤 3:

创建WebSocket处理程序类 然后,创建一个WebSocket处理程序类来处理WebSocket连接和消息。例如,创建一个名为ChatWebSocketHandler的类,并添加以下代码:

@Component
public class ChatWebSocketHandler extends TextWebSocketHandler {private static final List<WebSocketSession> sessions = new CopyOnWriteArrayList<>();@Overridepublic void afterConnectionEstablished(WebSocketSession session) throws Exception {sessions.add(session);}@Overrideprotected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {for (WebSocketSession client : sessions) {if (client.isOpen()) {client.sendMessage(message);}}}@Overridepublic void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {sessions.remove(session);}
}

步骤 4:

创建前端页面 接下来,您需要编写一个前端页面来与WebSocket进行通信。您可以使用JavaScript和HTML来实现此功能。以下是一个简单的示例:

<!DOCTYPE html>
<html>
<head><title>Chat</title><script src="https://code.jquery.com/jquery-3.6.0.min.js"></script><script>var socket = new WebSocket("ws://localhost:8080/chat");socket.onopen = function() {console.log("Connected to WebSocket");};socket.onmessage = function(event) {var message = event.data;console.log("Received message: " + message);// 在页面上显示收到的消息$("#messages").append("<p>" + message + "</p>");};function sendMessage() {var message = $("#message").val();socket.send(message);}</script>
</head>
<body><input type="text" id="message" placeholder="Enter a message"><button onclick="sendMessage()">Send</button><div id="messages"></div>
</body>
</html>

这是一个简单的聊天界面,用户可以在输入框中输入消息,并通过点击“发送”按钮将其发送给服务器。服务器将收到的消息广播给所有连接的客户端。

以上就是实现Spring Boot项目中消息对话的基本步骤和代码示例。请根据您的需求进行适当的修改和扩展。

http://www.lryc.cn/news/151841.html

相关文章:

  • 「Tech初见」Linux驱动之blkdev
  • ssh配置(二、登录服务器)
  • pytorch异常——RuntimeError:Given groups=1, weight of size..., expected of...
  • 【FPGA项目】沙盘演练——基础版报文收发
  • 【C++技能树】继承概念与解析
  • 计算机网络 第二节
  • 无涯教程-机器学习 - 矩阵图函数
  • Redis 高可用与集群
  • 修改文件名后Git仓上面并没有修改
  • Linux 信号
  • 深入探讨梯度下降:优化机器学习的关键步骤(二)
  • 高频算法面试题
  • Hive-启动与操作(2)
  • css transition 指南
  • LeetCode 面试题 02.05. 链表求和
  • 一米脸书营销软件
  • vue 根据数值判断颜色
  • Hugging Face 实战系列 总目录
  • 国标视频云服务EasyGBS国标视频平台迁移服务器后无法启动的问题解决方法
  • HTML <th> 标签
  • HTTP/1.1协议中的响应报文
  • TDengine函数大全-选择函数
  • 非关系型数据库Redis的安装
  • oracle 创建数据库
  • wxWidgets从空项目开始Hello World
  • 【Apollo学习笔记】——规划模块TASK之SPEED_DECIDER
  • 【操作系统】一文快速入门,很适合JAVA后端看
  • C++ Primer阅读笔记--allocator类的使用
  • 【C++历险记】面向对象|菱形继承及菱形虚拟继承
  • 【Locomotor运动模块】攀爬