news 2026/5/4 13:13:01

15. 实时数据-SpringBoot集成WebSocket

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
15. 实时数据-SpringBoot集成WebSocket

文章目录

  • 前言
    • 一、添加依赖(Maven)
    • 二、配置 WebSocket
      • 1. 创建 WebSocket 配置类
      • 2. 实现 WebSocket 处理器
    • 三、前端测试(HTML + JS)
    • 四、启动类(标准 Spring Boot 启动类)
    • 五、可选:使用 STOMP over WebSocket(更高级)
    • 六、注意事项

前言

SpringBoot集成WebSocket

在 Spring Boot 中集成 WebSocket 可以实现服务器与客户端之间的双向通信,常用于实时消息推送、聊天室、在线通知等场景。


一、添加依赖(Maven)

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

二、配置 WebSocket

1. 创建 WebSocket 配置类

importorg.springframework.context.annotation.Configuration;importorg.springframework.web.socket.config.annotation.EnableWebSocket;importorg.springframework.web.socket.config.annotation.WebSocketConfigurer;importorg.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;@Configuration@EnableWebSocketpublicclassWebSocketConfigimplementsWebSocketConfigurer{@OverridepublicvoidregisterWebSocketHandlers(WebSocketHandlerRegistryregistry){// 注册处理器,允许跨域访问registry.addHandler(myWebSocketHandler(),"/websocket").setAllowedOrigins("*");// 生产环境应限制具体域名}publicMyWebSocketHandlermyWebSocketHandler(){returnnewMyWebSocketHandler();}}

2. 实现 WebSocket 处理器

importorg.springframework.web.socket.CloseStatus;importorg.springframework.web.socket.TextMessage;importorg.springframework.web/socket.WebSocketSession;importorg.springframework.web.socket.handler.TextWebSocketHandler;importjava.util.concurrent.ConcurrentHashMap;publicclassMyWebSocketHandlerextendsTextWebSocketHandler{// 存储所有连接的会话privatestaticfinalConcurrentHashMap<String,WebSocketSession>sessions=newConcurrentHashMap<>();@OverridepublicvoidafterConnectionEstablished(WebSocketSessionsession)throwsException{sessions.put(session.getId(),session);System.out.println("新连接: "+session.getId());}@OverrideprotectedvoidhandleTextMessage(WebSocketSessionsession,TextMessagemessage)throwsException{Stringpayload=message.getPayload();System.out.println("收到消息: "+payload);// 广播给所有连接的客户端for(WebSocketSessions:sessions.values()){if(s.isOpen()){s.sendMessage(newTextMessage("Echo: "+payload));}}}@OverridepublicvoidafterConnectionClosed(WebSocketSessionsession,CloseStatusstatus)throwsException{sessions.remove(session.getId());System.out.println("连接关闭: "+session.getId());}@OverridepublicvoidhandleTransportError(WebSocketSessionsession,Throwableexception)throwsException{sessions.remove(session.getId());session.close(CloseStatus.SERVER_ERROR);System.out.println("连接异常: "+session.getId());}}

三、前端测试(HTML + JS)

<!DOCTYPEhtml><html><head><title>WebSocket 测试</title></head><body><inputtype="text"id="message"placeholder="输入消息"><buttononclick="sendMessage()">发送</button><divid="output"></div><script>constws=newWebSocket('ws://localhost:8080/websocket');ws.onopen=function(event){console.log('连接已建立');};ws.onmessage=function(event){document.getElementById('output').innerHTML+='<p>'+event.data+'</p>';};ws.onclose=function(event){console.log('连接已关闭');};functionsendMessage(){constmsg=document.getElementById('message').value;ws.send(msg);}</script></body></html>

四、启动类(标准 Spring Boot 启动类)

importorg.springframework.boot.SpringApplication;importorg.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplicationpublicclassWebsocketApplication{publicstaticvoidmain(String[]args){SpringApplication.run(WebsocketApplication.class,args);}}

五、可选:使用 STOMP over WebSocket(更高级)

如果你需要更复杂的协议(如订阅/发布、路径匹配、安全认证等),可以考虑使用STOMP协议,Spring Boot 对其有良好支持。


六、注意事项

  • setAllowedOrigins("*")在生产环境中应替换为具体的可信域名。
  • WebSocket 连接是长连接,注意资源释放和异常处理。
  • 若部署在 Nginx 或云服务后,需确保代理支持 WebSocket(设置 Upgrade 和 Connection 头)。

如需基于注解(@ServerEndpoint)的方式(使用原生 Java EE WebSocket API),也可以配合spring-boot-starter-websocket使用,但 Spring 推荐使用WebSocketHandler或 STOMP 方式。


本文的引用仅限自我学习如有侵权,请联系作者删除。
参考知识


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

30、FreeBSD 图形界面配置与 KDE 桌面环境使用指南

FreeBSD 图形界面配置与 KDE 桌面环境使用指南 1. X Window 系统配置 X Window 系统为 FreeBSD 提供了类似于 Windows 的图形用户界面。它与窗口管理器协同工作,为用户打造一个高效的工作环境。 1.1 关键配置文件与程序 XF86Config :这是控制 X Window 系统各种属性的文本…

作者头像 李华
网站建设 2026/5/4 8:57:31

项目中绝对位置和相对位置的具体应用解析

这个通常用于有外部库或者文件输入时&#xff0c;使用相对路径可避免代码复制到别的PC端没法使用的情况基础概念&#xff1a;路径分隔符的作用​在文件系统中&#xff0c;路径用于定位文件或目录的位置。反斜杠 \ 是 Windows 系统中的路径分隔符&#xff0c;而正斜杠 / 通常用于…

作者头像 李华
网站建设 2026/5/1 0:41:06

Doris笔记

Doris常用命令&#xff1a; 查看doris 某用户最大连接数 show property for 用户名 like max_user_connections设置单个用户并发数连接&#xff08;立即生效&#xff09; SET PROPERTY FOR 用户名 max_user_connections 500;设置全局的最大并发数连接&#xff08;所有用户的…

作者头像 李华
网站建设 2026/5/2 11:48:36

ThinkingEngine的首个AI原生能力来了!

移动互联网的普及与社交媒体的蓬勃发展&#xff0c;让用户发声的渠道愈发多元且直接。从国内外主流媒体与社区&#xff0c;到企业社群、客户群等私域场景&#xff0c;这些来自用户自发的、实时的对话&#xff0c;往往直接反映了市场对产品的真实感受、未被满足的潜在需求以及正…

作者头像 李华
网站建设 2026/5/1 0:41:18

解决 macOS 26.1 The application “xxxx” can’t be opened. 问题

报错如下&#xff1a; “xxx.app” is damaged and can’t be opened. You should move it to the Trash.The application “Charles” can’t be opened.非 M 系列芯片可以通过下面的命令解决&#xff1a; sudo xattr -rd com.apple.quarantine /Applications/xxx.app M 芯片解…

作者头像 李华