美文网首页
WebSocket 机制 - 草稿

WebSocket 机制 - 草稿

作者: 芹菜斯_嘉丽 | 来源:发表于2017-09-29 13:30 被阅读0次

WebSocket 是 HTML5 一种新的协议。它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯,它建立在 TCP 之上,同 HTTP 一样通过 TCP 来传输数据,但是它和 HTTP 最大不同是:

1.WebSocket 是一种双向通信协议,在建立连接后,WebSocket 服务器和 Browser/Client Agent 都能主动的向对方发送或接收数据,就像 Socket 一样;

2.WebSocket 需要类似 TCP 的客户端和服务器端通过握手连接,连接成功后才能相互通信。

   相对于传统 HTTP 每次请求-应答都需要客户端与服务端建立连接的模式,WebSocket 是类似 Socket 的 TCP 长连接的通讯模式,一旦 WebSocket 连接建立后,后续数据都以帧序列的形式传输。在客户端断开 WebSocket 连接或 Server 端断掉连接前,不需要客户端和服务端重新发起连接请求。在海量并发及客户端与服务器交互负载流量大的情况下,极大的节省了网络带宽资源的消耗,有明显的性能优势,且客户端发送和接受消息是在同一个持久连接上发起,实时性优势明显。

WebSocket握手请求(使用http请求完成)

清单 1.WebSocket 客户端连接报文

GET /webfin/websocket/ HTTP/1.1

Host: localhost

Upgrade: websocket

Connection: UpgradeSec-WebSocket-Key: xqBt3ImNzJbYqRINxEFlkg==

Origin:http://localhost:8080

Sec-WebSocket-Version: 13

////”Upgrade:websocket”参数值表明这是 WebSocket 类型请求,WebSocket-Key”是 WebSocket 客户端发送的一个 base64 编码的密文,要求服务端必须返回一个对应加/密的“Sec-WebSocket-Accept”应答,否则客户端会抛出“Error during WebSocket handshake”错误,并关闭连接。

清单:2.WebSocket 服务端响应报文

HTTP/1.1 101 Switching Protocols

Upgrade: websocket

Connection: Upgrade

Sec-WebSocket-Accept: K7DJLdLooIwIG/MOpvWFB3y3FE8=

////“Sec-WebSocket-Accept”的值是服务端采用与客户端一致的密钥计算出来后返回客户端的,“HTTP/1.1 101 Switching Protocols”表示服务端接受 WebSocket 协议的客户端连接。

webSocket 客户端实例

// 创建一个Socket实例

var socket = new WebSocket('ws://localhost:8080');//服务器地址

// 打开Socket

socket.onopen = function(event) {

// 发送一个初始化消息

socket.send('I am the client and I\'m listening!');

// 监听消息

socket.onmessage = function(event) {

console.log('Client received a message',event);//???event.data???接收数据

};

// 监听Socket的关闭

socket.onclose = function(event) {

console.log('Client notified socket has closed',event);

};

// 关闭Socket....

//socket.close()

webSocket 规范定义了ws和wss两种url模式,ws 用于非加密连接,wss用于加密连接。

相关文章

  • WebSocket 机制 - 草稿

    WebSocket 是 HTML5 一种新的协议。它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并...

  • angular7项目开发踩坑之websocket

    版本"angular2-websocket":"^0.9.8" 现象 由于websocket的长连接机制,在Chr...

  • WebSocket 机制

    WebSocket 是 HTML5 一种新的协议。它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并...

  • nodejs 开发websocket 笔记

    使用nodejs 开发websocket消息分发系统 websocket使用事件触发机制传输密集传输数据,跟nod...

  • 基于php swoole扩展写的超简单聊天室

    实例图: 服务端 Websocket.php 启动:php websocket.php重启机制:先杀死进程,再重新...

  • WebSocket协议-原理篇

    本篇文章主要讲述以下几点: WebSocket的原理与机制 WebSocket与Socket.io WebSock...

  • 维护websocket长链接的稳定

    一,websocket常遇到哪些不理因素 1,假死 websocket 有自我检测机制,当断开连接的时候会发起重连...

  • tech notes

    前端: 修改input type = 'file'的默认样式 JavaScript 执行机制 WebSocket ...

  • Spring Boot系列WebSocket集成简单消息代理

    1. 概述 本文介绍webSocket相关的内容,主要有如下内容: WebSocket的诞生的背景、运行机制和抓包...

  • WebSocket

    WebSocket 机制 WebSocket 是 HTML5 一种新的协议。它实现了浏览器与服务器全双工通信,能更...

网友评论

      本文标题:WebSocket 机制 - 草稿

      本文链接:https://www.haomeiwen.com/subject/uexlzttx.html