Spring Boot整合WebSocket

目录

?引言

[1.WebSocket 基础知识](#1.WebSocket 基础知识)

[?1.1 什么是 WebSocket?](#?1.1 什么是 WebSocket?)

[?1.2 WebSocket 的应用场景](#?1.2 WebSocket 的应用场景)

[?2.Spring Boot WebSocket 整合步骤](#?2.Spring Boot WebSocket 整合步骤)

[2.1 创建 Spring Boot 项目](#2.1 创建 Spring Boot 项目)

[2.2 添加 Maven 依赖](#2.2 添加 Maven 依赖)

[2.3 配置 WebSocket](#2.3 配置 WebSocket)

[2.4 创建 WebSocket 控制器](#2.4 创建 WebSocket 控制器)

[2.5 创建前端页面](#2.5 创建前端页面)


引言

在现代 web 应用中,实时通信变得越来越重要。传统的 HTTP 请求-响应模型并不适合需要实时更新的场景,例如在线聊天、实时通知、在线游戏等。WebSocket 协议提供了一种在单个连接上进行双向通信的方式,能够有效地解决这一问题。Spring Boot 作为一个快速开发框架,提供了对 WebSocket 的良好支持,使得开发者能够快速构建基于 WebSocket 的应用。

本文将详细介绍如何在 Spring Boot 中整合 WebSocket,分为多个部分,包括 WebSocket 的基本概念、Spring Boot 的相关配置、实现步骤以及一些常见问题和最佳实践。

1.WebSocket 基础知识

1.1 什么是 WebSocket?

WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。它允许客户端和服务器之间进行实时数据交换,而无需每次都重新建立连接。WebSocket 的核心特性包括:

双向通信:客户端和服务器都可以主动发送和接收消息。

低延迟:由于 WebSocket 连接是持久的,消息可以立即传递,而不需要重复的 HTTP 请求。

节省资源:通过减少 HTTP 请求的开销,WebSocket 可以节省带宽和服务器资源。

1.2 WebSocket 的应用场景

WebSocket 适用于多种实时交互的场景,包括但不限于:

实时聊天应用

在线游戏

实时数据监控

股票行情推送

实时通知

2.Spring Boot WebSocket 整合步骤

2.1 创建 Spring Boot 项目

首先,我们需要创建一个新的 Spring Boot 项目。可以使用 Spring Initializr(https://start.spring.io/)生成一个基础项目,选择以下依赖:

  • Spring Web

  • Spring WebSocket

  • Spring Boot DevTools(可选,用于开发时热重启)

2.2 添加 Maven 依赖

在 `pom.xml` 中添加 WebSocket 的相关依赖(如果使用 Spring Initializr 创建项目,这些依赖会自动添加):

xml

org.springframework.boot

spring-boot-starter-websocket

2.3 配置 WebSocket

在项目中创建一个配置类,配置 WebSocket 的端点和消息代理。

```java

package com.example.demo.config;

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 {

@Override

public void registerStompEndpoints(StompEndpointRegistry registry) {

// 注册 STOMP 协议的 endpoint,并指定使用 SockJS 协议

registry.addEndpoint("/ws").withSockJS();

}

@Override

public void configureMessageBroker(MessageBrokerRegistry config) {

// 配置消息代理

config.enableSimpleBroker("/topic", "/queue");

config.setApplicationDestinationPrefixes("/app");

}

}

```

2.4 创建 WebSocket 控制器

接下来,我们需要创建一个控制器来处理 WebSocket 消息。

```java

package com.example.demo.controller;

import org.springframework.messaging.handler.annotation.MessageMapping;

import org.springframework.messaging.handler.annotation.SendTo;

import org.springframework.stereotype.Controller;

@Controller

public class WebSocketController {

@MessageMapping("/send")

@SendTo("/topic/messages")

public String sendMessage(String message) {

return message; // 返回接收到的消息

}

}

2.5 创建前端页面

在 `src/main/resources/templates` 目录下创建一个 `index.html` 文件,用于测试 WebSocket。

```html
WebSocket Demo

WebSocket Demo

Send

相关推荐
树上有只程序猿3 分钟前
低代码何时能出个“秦始皇”一统天下?我是真学不动啦!
前端·后端·低代码
2501_921649494 分钟前
期货 Tick 级数据与基金净值历史数据 API 接口详解
开发语言·后端·python·websocket·金融·区块链
架构师沉默5 分钟前
AI 写的代码,你敢上线吗?
java·后端·架构
Nyarlathotep011325 分钟前
Redis的内存回收和对象共享
redis·后端
我叫黑大帅31 分钟前
Go 中最强大的权限控制库(Casbin)
后端·面试·go
腾讯云云开发1 小时前
用 OpenClaw + CloudBase 自动化开发网站:30分钟从安装到上线
后端·ai编程
独断万古他化1 小时前
【Java 实战项目】多用户网页版聊天室:消息传输模块 —— 基于 WebSocket 实现实时通信
java·spring boot·后端·websocket·ajax·mybatis
舒一笑1 小时前
🚀 我用一行命令,把 OSS 私有文件变成“可直接下载的公网链接”(很多人不会)
后端
小兔崽子去哪了2 小时前
Docker 安装 PostgreSQL
数据库·后端·postgresql
Sweet锦2 小时前
SpringBoot 3.5 集成 InfluxDB 1.8
spring boot·时序数据库