世界快看:Spring Boot中的WebSocket

2023-03-09 15:52:31 来源:程序员客栈 分享到:
须弥零一
Spring Boot中的WebSocket

很多网站为了实现推送技术,所用的技术都是轮询。轮询是在特定的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。

在这种情况下,HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯。


(资料图片)

简介

WebSocket是一种在单个TCP连接上进行全双工通信的协议。

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接,并进行双向数据传输。

特点

•较少的控制开销。相对于HTTP请求每次都要携带完整的头部,开销显著减少了。

•更强的实时性。由于协议是全双工的,所以服务器可以随时主动给客户端下发数据。

•保持连接状态。Websocket需要先创建连接,是一种有状态的协议,之后通信时可以省略部分状态信息。而HTTP请求可能需要在每个请求都携带状态信息(如身份认证等)。

•更好的二进制支持。Websocket定义了二进制帧,相对HTTP,可以更轻松地处理二进制内容。

•可以支持扩展。Websocket定义了扩展,用户可以扩展协议、实现部分自定义的子协议。如部分浏览器支持压缩等。

•更好的压缩效果。相对于HTTP压缩,Websocket在适当的扩展支持下,可以沿用之前内容的上下文,在传递类似的数据时,可以显著地提高压缩率。

在SpringBoot项目中创建WebSocket Server项目依赖(Maven)

4.0.0cn.jeremysongdemo1.0org.springframework.bootspring-boot-starter-parent3.0.3org.springframework.bootspring-boot-starter-websocket3.0.3

WebSocket服务

importorg.springframework.context.annotation.Bean;importorg.springframework.stereotype.Component;importorg.springframework.web.socket.server.standard.ServerEndpointExporter;/***ServerEndpointExporter作用**这个Bean会自动注册使用@ServerEndpoint注解声明的websocketendpoint**/@ComponentpublicclassWebSocketConfig{@BeanpublicServerEndPointExporterserverEndPointExporter(){returnnewServerEndPointExporter();}}

importlombok.extern.slf4j.Slf4j;importorg.springframework.stereotype.Component;importjavax.websocket.OnClose;importjavax.websocket.OnMessage;importjavax.websocket.OnOpen;importjavax.websocket.Session;importjavax.websocket.server.PathParam;importjavax.websocket.server.ServerEndpoint;importjava.io.IOException;importjava.util.concurrent.ConcurrentHashMap;@Slf4j@Component@ServerEndpoint("/websocket/{name}")publicclassWebSocket{privateSessionsession;privateStringname;privatestaticConcurrentHashMapwebSocketSet=newConcurrentHashMap<>();@OnOpenpublicvoidonOpen(Sessionsession,@PathParam(value="name")Stringname){this.session=session;this.name=name;webSocketSet.put(name,this);}@OnClosepublicvoidonClose(){webSocketSet.remove(this.name);}@OnMessagepublicvoidonMessage(Stringmessage){log.info("{}send{}",this.name,message);}/***群发*@parammessage消息内容*/publicvoidgroupSending(Stringmessage){for(Stringname:webSocketSet.keySet()){try{webSocketSet.get(name).session.getBasicRemote().sendText(message);}catch(IOExceptione){e.printStackTrace();}}}/***指定发动消息*@paramname指定的客户端名*@parammessage消息内容*/publicvoidappointSending(Stringname,Stringmessage){try{webSocketSet.get(name).session.getBasicRemote().sendText(message);}catch(IOExceptione){e.printStackTrace();}}}

使用JavaScript创建WebSocket ClientWebSocket客户端

letwebsocket=null;if("WebSocket"inwindow){websocket=newWebSocket("ws://localhost:8888/websocket/cli-1");websocket.onopen=function(){console.log("连接成功");};websocket.onclose=function(){console.log("退出连接");};websocket.onmessage=function(event){console.log("收到消息:"+event.data);};websocket.onerror=function(){console.log("连接出错");};//MDNExamplewebsocket.addEventListener("open",function(event){websocket.send("HelloServer!");});websocket.addEventListener("message",function(event){console.log("Messagefromserver",event.data);});websocket.addEventListener("error",function(event){console.log("WebScoketerror:",event);});}window.onbeforeunload=function(){//页面关闭时关闭WebSocket连接websocket.close(1000);};

在Chrome console中测试

执行如下命令时可以在Server端添加日志输出和debug观察交互现象。

>ws1=newWebSocket("ws://localhost:8888/websocket/name1");>ws1.send("Sendmessagetoserver!Iamname1");>ws2=newWebSocket("ws://localhost:8888/websocket/name2");>ws2.send("Sendmessagetoserver!Iamname2");>ws1.close(1000);>ws2.close(1000);

参考

•WebSocket - MDN:

https://developer.mozilla.org/zh-CN/docs/Web/API/WebSocket

•CloseEvent - MDN:

https://developer.mozilla.org/zh-CN/docs/Web/API/CloseEvent#status_codes
---- END ----

欢迎关注我的公众号“须弥零一”,原创技术文章第一时间推送。

标签:

世界快看:Spring Boot中的WebSocket

来源:程序员客栈 2023-03-09 15:52:31

期待了!比亚迪F品牌将搭载全新混动系统 售价40-60万元_世界关注

来源:CNMO手机中国 2023-03-09 13:50:30

热点在线丨上古卷轴5ece捏脸存档怎么用_上古卷轴5ece捏脸存档

来源:互联网 2023-03-09 13:56:01

环球今热点:感染HPV≠得宫颈癌!有份给女性朋友的重要提示请查收→

来源:环球网 2023-03-09 11:09:48

国家统计局:PPI同比降幅比上月扩大0.6个百分点

来源:金融界 2023-03-09 09:44:59

什么的眉毛填空答案_什么的眉毛填空:环球短讯

来源:互联网 2023-03-09 08:03:38

乌龟冬天怎么养_这三点需谨记-当前热议

来源:互联网 2023-03-09 07:01:59

快讯2023-03-08 23:39:55

来源:财联社 2023-03-09 01:21:40

关岛旅游攻略 关岛旅游攻略

来源:互联网 2023-03-08 22:13:57

广西二本大学有哪些学校2020_广西二本大学有哪些

来源:互联网 2023-03-08 21:11:24

中性清洗剂介绍 全球报道

来源:万年历 2023-03-08 18:40:20

妇女节特辑|妇女参与,关坝村悄然而深刻的变化

来源:山水自然保护中心 2023-03-08 18:08:15

天天热消息:03月08日12时广东云浮疫情数据 阳了以后为什么会腰疼?应该怎么办?

来源:互联网 2023-03-08 16:13:59

len

来源:互联网 2023-03-08 15:33:38

焦点简讯:三星gt n7108d_三星gt n7108d

来源:互联网 2023-03-08 14:13:04

敖厂长

来源:互联网 2023-03-08 12:22:22

行尸走肉第二季在线播放_行尸走肉第二季在线

来源:互联网 2023-03-08 11:56:19

世界观焦点:我从基层来丨全国政协委员蒋齐:筑牢西北生态安全屏障

来源:央视新闻客户端 2023-03-08 09:48:56

皈依的仪式主要是什么|天天快播

来源:万年历 2023-03-08 09:03:00

观点:猪油_说一说猪油的简介

来源:互联网 2023-03-08 07:41:06

黑烟囱|新消息

来源:互联网 2023-03-08 05:44:42

全球看热讯:小米手机黑屏怎么解决视频_小米手机黑屏怎么解决

来源:互联网 2023-03-08 03:13:51

环球观速讯丨文章身高_关于文章身高的介绍

来源:元宇宙网 2023-03-07 22:48:32

天天头条:东成西就插曲

来源:互联网 2023-03-07 21:51:44

红薯粉热量高还是土豆粉热量高-红薯粉热量

来源:互联网 2023-03-07 19:59:40

快播:吃亏是福

来源:互联网 2023-03-07 18:49:42

东风汽车今日涨停 机构合计净卖出545.22万元

来源:金融界 2023-03-07 18:03:39

依旧近义词的近义词

来源:互联网 2023-03-07 15:57:01

肯定的近义词和反义词

来源:万年历 2023-03-07 15:45:32

万丰奥威董秘回复:公司镁合金业务保持稳健发展,目前公司重点推进镁合金业务亚太中心建设,导入北美成熟管理体系

来源:证券之星 2023-03-07 13:52:55

Copyright   2015-2022 世界知识产权网 版权所有  备案号:琼ICP备2022009675号-1   联系邮箱:435 227 67@qq.com