news 2026/5/7 8:11:52

WebSocket 消息推送:Spring Boot + Vue3 实现一个“网页版即时聊天室”(附源码)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
WebSocket 消息推送:Spring Boot + Vue3 实现一个“网页版即时聊天室”(附源码)

💬 前言:为什么轮询 (Polling) 被淘汰了?

在 Web 1.0 时代,如果我们要实现“收到新消息提醒”,通常只能让前端每隔 2 秒发一次 HTTP 请求问后端:“有新消息吗?”
这叫短轮询

  • 缺点:服务器压力大,99% 的请求都是无用的,且消息有延迟。

到了 Web 2.0,WebSocket横空出世。
它像一条**“专线管道”,一旦建立连接,服务器就可以主动**把消息推给前端。

  • 优点:零延迟,服务器资源消耗极低,全双工通讯。

今天,我们就用最主流的Spring Boot + Vue3,在 30 分钟内手撸一个多人在线聊天室!


🏗️ 系统架构:一条永不断的线

我们要实现的功能:

  1. 用户登录(输入昵称)。
  2. 进入群聊,显示在线人数。
  3. 发送消息,所有人(包括自己)实时收到。

架构设计图:

WebSocket_Server_内存
1. 建立 WS 连接
1. 建立 WS 连接
2. 发送消息 Hello
3. 查找所有在线 Session
4. 推送消息
4. 推送消息
ConcurrentHashMap Session池
用户 A Vue3
Spring Boot 后端
用户 B Vue3

💻 后端实战:Spring Boot + WebSocket

不需要 Netty,Spring Boot 自带的 WebSocket 模块足够应对中小规模场景。

1. 引入依赖
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId></dependency>
2. 开启支持 (WebSocketConfig.java)
@ConfigurationpublicclassWebSocketConfig{@BeanpublicServerEndpointExporterserverEndpointExporter(){returnnewServerEndpointExporter();}}
3. 核心服务 (WebSocketServer.java)

这是整个聊天室的心脏。

@ServerEndpoint("/ws/{username}")// 前端连接地址: ws://localhost:8080/ws/张三@Component@Slf4jpublicclassWebSocketServer{// 存放每个客户端对应的 WebSocketServer 对象privatestaticConcurrentHashMap<String,Session>onlineSessions=newConcurrentHashMap<>();@OnOpenpublicvoidonOpen(Sessionsession,@PathParam("username")Stringusername){onlineSessions.put(username,session);broadcast("系统消息: 欢迎用户 ["+username+"] 加入群聊!");}@OnClosepublicvoidonClose(@PathParam("username")Stringusername){onlineSessions.remove(username);broadcast("系统消息: 用户 ["+username+"] 已离开。");}@OnMessagepublicvoidonMessage(Stringmessage,Sessionsession,@PathParam("username")Stringusername){// 收到消息,转发给所有人broadcast("【"+username+"】: "+message);}// 群发消息辅助方法privatevoidbroadcast(Stringmsg){onlineSessions.forEach((user,session)->{try{session.getBasicRemote().sendText(msg);}catch(IOExceptione){e.printStackTrace();}});}}

🎨 前端实战:Vue 3 Composition API

Vue3 写 WebSocket 简直不要太丝滑。

<template><divclass="chat-box"><divclass="msg-list"ref="msgRef"><divv-for="msg in msgList":key="msg">{{ msg }}</div></div><divclass="input-area"><inputv-model="inputMsg"placeholder="输入消息..."/><button@click="sendMsg">发送</button></div></div></template><scriptsetup>import{ref,onMounted,onUnmounted}from'vue';constusername='User_'+Math.floor(Math.random()*1000);constsocketUrl=`ws://localhost:8080/ws/${username}`;constmsgList=ref([]);constinputMsg=ref('');letws=null;onMounted(()=>{initWebSocket();});constinitWebSocket=()=>{ws=newWebSocket(socketUrl);ws.onopen=()=>{msgList.value.push("✅ 连接服务器成功...");};ws.onmessage=(event)=>{// 收到后端推送的消息msgList.value.push(event.data);};};constsendMsg=()=>{if(ws&&inputMsg.value){ws.send(inputMsg.value);inputMsg.value='';}};onUnmounted(()=>{if(ws)ws.close();// 页面销毁时断开连接});</script>

🛡️ 进阶挑战:心跳检测与断线重连

在真实生产环境中,网络是不稳定的。如果用户断网了,WebSocket 连接会“假死”。
你需要实现心跳机制 (Heartbeat)

  1. Ping/Pong:前端每隔 30 秒发送一个 “PING”,后端回复 “PONG”。
  2. 断线重连:前端监听ws.onclose事件,如果非主动断开,则在 5 秒后尝试重新new WebSocket()

(这部分代码在下方的源码中均有体现)


🎁 源码推荐与下载

如果你想看企业级的 IM 架构(支持千万级并发、集群部署、Redis 存储离线消息),那么仅仅看 Spring Boot 原生 WebSocket 是不够的,你需要引入Netty

我为你精选了一个 GitHub 上1.4万+ Star的神级项目,它是 Java 领域即时通讯的标杆。

开源项目:CIM (Cross-platform Instant Messaging)

  • GitHub 地址https://github.com/crossoverJie/cim
  • 推荐理由
    1. 基于Netty + Spring Boot + Redis构建,性能吊打原生 WebSocket。
    2. 代码结构清晰,包含命令行客户端、Web 客户端、安卓客户端。
    3. 文档极其详细,适合做毕业设计或企业内部通讯系统的底座。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/4 10:08:48

桌宠交互性能优化实战:如何解决触摸延迟与动画卡顿问题

桌宠交互性能优化实战&#xff1a;如何解决触摸延迟与动画卡顿问题 【免费下载链接】VPet 虚拟桌宠模拟器 一个开源的桌宠软件, 可以内置到任何WPF应用程序 项目地址: https://gitcode.com/GitHub_Trending/vp/VPet 在虚拟宠物应用中&#xff0c;触摸反馈的即时性和动画…

作者头像 李华
网站建设 2026/4/24 18:25:21

Zotero AI插件终极指南:3分钟快速部署智能文献助手

Zotero AI插件终极指南&#xff1a;3分钟快速部署智能文献助手 【免费下载链接】papersgpt-for-zotero Zotero chat PDF with DeepSeek, GPT, ChatGPT, Claude, Gemini 项目地址: https://gitcode.com/gh_mirrors/pa/papersgpt-for-zotero 还在为海量学术文献感到头疼吗…

作者头像 李华
网站建设 2026/5/3 10:59:59

学生党最爱省钱爱创猫AI APP

外卖点出大餐感&#xff0c;网购省出新高度&#xff1a;学生党的精打细算实战手册每个月末&#xff0c;看着账单上那些不起眼的外卖订单和购物记录&#xff0c;是不是总感觉钱不知不觉就“蒸发”了&#xff1f;一杯奶茶、一次凑单、一个“限时秒杀”&#xff0c;积少成多&#…

作者头像 李华
网站建设 2026/5/1 10:40:28

将PDF转化为RAG文件,进行数据清洗

在本地 RAG 系统中使用 Marker&#xff1a;高精度 PDF 到 Markdown 的离线开源解决方案&#xff08;2025 更新&#xff09; 在本地 RAG&#xff08;Retrieval-Augmented Generation&#xff09;系统中&#xff0c;PDF 解析质量是决定最终问答准确率的关键&#xff08;Garbage …

作者头像 李华
网站建设 2026/5/6 16:19:47

Linux内核实时调度:从基础到实战的终极指南

Linux内核实时调度&#xff1a;从基础到实战的终极指南 【免费下载链接】linux-insides-zh Linux 内核揭秘 项目地址: https://gitcode.com/gh_mirrors/li/linux-insides-zh 在当今的嵌入式系统和工业自动化领域&#xff0c;实时性已成为系统设计的核心考量。你是否曾面…

作者头像 李华
网站建设 2026/4/25 2:10:27

大数据领域数据治理的核心要点与实践策略

大数据领域数据治理的核心要点与实践策略 1. 引入与连接 1.1 引人入胜的开场 在当今数字化时代&#xff0c;数据就如同石油一般&#xff0c;是企业和社会发展的重要资源。想象一下&#xff0c;一家大型电商企业&#xff0c;每天都能收集到海量的数据&#xff0c;包括用户的浏览…

作者头像 李华