当前位置:首页 > 科技  > 软件

详解基于SpringBoot的WebSocket应用开发

来源: 责编: 时间:2024-03-19 09:22:30 116观看
导读在现代Web应用中,实时交互和数据推送的需求日益增长。WebSocket协议作为一种全双工通信协议,允许服务端与客户端之间建立持久性的连接,实现实时、双向的数据传输,极大地提升了用户体验。本文将详细介绍如何在Spring Boot

vkG28资讯网——每日最新资讯28at.com

在现代Web应用中,实时交互和数据推送的需求日益增长。WebSocket协议作为一种全双工通信协议,允许服务端与客户端之间建立持久性的连接,实现实时、双向的数据传输,极大地提升了用户体验。本文将详细介绍如何在Spring Boot框架中使用WebSocket进行高效、稳定的实时通信。vkG28资讯网——每日最新资讯28at.com

WebSocket简介

WebSocket是一种在单个TCP连接上进行全双工通信的协议,其最大的特点是服务器可以主动向客户端发送消息,而不需要客户端先发起请求。相较于传统的HTTP长轮询或轮询机制,WebSocket能有效减少不必要的网络通信开销,并提供更优的实时性。vkG28资讯网——每日最新资讯28at.com

SpringBoot集成WebSocket

添加依赖

首先,在Spring Boot项目中引入WebSocket支持。在pom.xml文件中添加如下依赖:vkG28资讯网——每日最新资讯28at.com

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

创建WebSocket配置类

创建一个WebSocket配置类,通过WebSocketConfigurer接口来自定义WebSocket处理逻辑。例如:vkG28资讯网——每日最新资讯28at.com

@Configuration@EnableWebSocketpublic class WebSocketConfig implements WebSocketConfigurer {    @Override    public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {        // 注册WebSocket处理器,指定访问路径        registry.addHandler(myWebSocketHandler(), "/webSocket/{sid}");    }    @Bean    public WebSocketHandler myWebSocketHandler() {        return new MyWebSocketHandler();    }}

实现WebSocket处理器

创建一个实现WebSocketHandler接口的类,如MyWebSocketHandler,并重写其中的方法以处理WebSocket的生命周期事件(如打开、关闭、接收消息等):vkG28资讯网——每日最新资讯28at.com

@Componentpublic class MyWebSocketHandler implements WebSocketHandler {    private static final CopyOnWriteArraySet<MyWebSocketHandler> webSocketSet = new CopyOnWriteArraySet<>();    private Session session;    private String sid;    @Override    public void afterConnectionEstablished(Session session) throws Exception {        this.session = session;        sid = session.getAttributes().get("sid").toString();        webSocketSet.add(this);        log.info("WebSocket连接已建立, sid: {}", sid);    }    @Override    public void handleMessage(String message, Session session) throws IOException {        log.info("接收到{}的信息: {}", sid, message);        // 群发消息或其他处理逻辑        for (MyWebSocketHandler item : webSocketSet) {            try {                if (item.sid.equals(sid)) {                    item.sendMessage(message);                }            } catch (IOException e) {                log.error("发送消息时发生错误", e);            }        }    }    @Override    public void handleTransportError(Throwable exception, Session session) {        if (session.isOpen()) {            session.close();        }        webSocketSet.remove(this);        log.error("WebSocket连接发生错误", exception);    }    @Override    public void afterConnectionClosed(Session session, CloseStatus status) {        webSocketSet.remove(this);        log.info("WebSocket连接已关闭, sid: {}, 原因: {}", sid, status.getReason());    }    @Override    public boolean supportsPartialMessages() {        return false;    }    private void sendMessage(String message) throws IOException {        session.getBasicRemote().sendText(message);    }        // 可以增加根据sid筛选的消息推送方法    public static void sendInfo(SocketMsg socketMsg, String targetSid) throws IOException {        // ...    }}

客户端连接WebSocket

在前端JavaScript代码中使用WebSocket API与后端建立连接,并处理各种事件:vkG28资讯网——每日最新资讯28at.com

var ws = new WebSocket('ws://localhost:8080/webSocket/' + uniqueSessionId);ws.onopen = function(event) {    console.log('WebSocket连接已建立');};ws.onmessage = function(event) {    console.log('接收到服务器消息:', event.data);};ws.onerror = function(error) {    console.error('WebSocket连接发生错误:', error);};ws.onclose = function(event) {    console.log('WebSocket连接已关闭,原因:', event.reason);};// 发送消息到服务器ws.send(JSON.stringify({message: 'Hello, Server!'}));

总结

通过上述步骤,我们已经在Spring Boot项目中成功实现了WebSocket功能。需要注意的是,实际应用场景中可能需要对用户权限、连接管理、消息队列、心跳检测等功能进行更细致的设计与实现,以确保WebSocket服务的稳定性和性能表现。同时,WebSocket技术的应用场景非常广泛,包括但不限于即时聊天、在线协作、实时监控等。vkG28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-77680-0.html详解基于SpringBoot的WebSocket应用开发

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Rust学习笔记:基础概念介绍

下一篇: Vue3问题:如何在页面上添加水印?

标签:
  • 热门焦点
  • 2023 年的 Node.js 生态系统

    2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • 不容错过的MSBuild技巧,必备用法详解和实践指南

    不容错过的MSBuild技巧,必备用法详解和实践指南

    一、MSBuild简介MSBuild是一种基于XML的构建引擎,用于在.NET Framework和.NET Core应用程序中自动化构建过程。它是Visual Studio的构建引擎,可在命令行或其他构建工具中使用
  • 得物效率前端微应用推进过程与思考

    得物效率前端微应用推进过程与思考

    一、背景效率工程随着业务的发展,组织规模的扩大,越来越多的企业开始意识到协作效率对于企业团队的重要性,甚至是决定其在某个行业竞争中突围的关键,是企业长久生存的根本。得物
  • JavaScript学习 -AES加密算法

    JavaScript学习 -AES加密算法

    引言在当今数字化时代,前端应用程序扮演着重要角色,用户的敏感数据经常在前端进行加密和解密操作。然而,这样的操作在网络传输和存储中可能会受到恶意攻击的威胁。为了确保数据
  • 一个注解实现接口幂等,这样才优雅!

    一个注解实现接口幂等,这样才优雅!

    场景码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:图片上述代码有
  • 拼多多APP上线本地生活入口,群雄逐鹿万亿市场

    拼多多APP上线本地生活入口,群雄逐鹿万亿市场

    Tech星球(微信ID:tech618)文 | 陈桥辉 Tech星球独家获悉,拼多多在其APP内上线了&ldquo;本地生活&rdquo;入口,位置较深,位于首页的&ldquo;充值中心&rdquo;内,目前主要售卖美食相关的
  • 当家的盒马,加速谋生

    当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己&ldquo;当家&rdquo;的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  •  三星推出Galaxy Tab S9系列平板电脑以及Galaxy Watch6系列智能手表

    三星推出Galaxy Tab S9系列平板电脑以及Galaxy Watch6系列智能手表

    2023年7月26日,三星电子正式发布了Galaxy Z Flip5与Galaxy Z Fold5。除此之外,Galaxy Tab S9系列平板电脑以及三星Galaxy Watch6系列智能手表也同期
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top
Baidu
map