张店网站制作哪家好,青岛市专业做网站的吗,深圳设计展2022,重庆的汽车网站建设文章目录 什么是WebSocket?WebSocket连接过程WebSocket与Http的区别重连机制完整代码使用方法心跳机制实现聊天室demo(基于Socket.io)参考文章、视频小广告~什么是WebSocket? WebSocket 是一种在单个TCP连接上进行全双工通信的协议(计算机网络应用层的协议) 在 WebSocket A… 文章目录 什么是WebSocket?WebSocket连接过程 WebSocket与Http的区别重连机制完整代码使用方法 心跳机制实现聊天室demo(基于Socket.io)参考文章、视频小广告~ 什么是WebSocket? WebSocket 是一种在单个TCP连接上进行全双工通信的协议(计算机网络应用层的协议) 在 WebSocket API 中,浏览器和服务器只需要完成一次握手,两者之间就直接可以创建持久性的连接, 并进行双向数据传输。(维基百科) 特点:
与HTTP协议有良好的兼容性,默认端口也是80和443,握手阶段采用HTTP协议建立在TCP协议之上,服务端的实现比较容易WebSocket连接过程 建立握手 客户端发起HTTP请求,请求头中含有 Connection: Upgrade
Upgrade: Websocket
Sec-WebSocket-Key: xxx // 提供给服务器来验证是否收到一个有效的WebSockets请求
Sec-WebSocket-Version: xxx // 版本服务器收到之后,明白要升级websocket连接。向客户端发送101状态码的响应 101 Switching Protocols
Connection: Upgrade
Upgrade: Websocket
Sec-WebSocket-Accept: xxx之后就可以进行双端通信 WebSocket与Http的区别 二者都是基于TCP,都是应用层协议。但是websocket只是在建立握手时,数据是通过HTTP传输的。重连机制
目的是防止WebSocket,断开连接时,能主动重连(区分主动断开,不进行重连)
完整代码
// 订阅发布--EventDispatcher
class EventDispatcher {listeners= {};addEventListener(type, listener) { // 收集依赖if (!this.listeners[type]) {this.listeners[type] = [];}if (this.listeners[type].indexOf(listener) === -1) {this.listeners[type].push(listener);}}removeEventListener(type) { // 清空依赖this.listeners[type] = [];}dispatchEvent(type, data) { // 循环执行callbackconst listenerArray = this.listeners[type] || [];if (listenerArray.length === 0) return;listenerArray.forEach(listener = {listener