codecamp

Websocket 基础入门

same-orgins:浏览器同源策略的安全模型

持久化协议

双向双工 多路复用, 同时发信息

http只能由客户端发起,一个request对应一个response

http每次通信需要发起连接,或者keepalived只能服用连接

http 头信息繁重

单一的TCP连接,采用全双工通信 vs 单向传送,需要多条连接

对代理,防火墙和路由透明: 基于http协议结构,使用相同80 443端口

连接建立后,信息传输无头部信息,减少网络带宽消耗、cookie和身份验证

无安全开销

通过ping/pong帧保持链路激活

服务器可以推消息。

websocket本质上是一个TCP连接

建立连接:发送http请求(upgrade:websocket升级),TCP三次握手,建立连接。

请求:

GET / HTTP/1.1 Host: Upgrade: websocket Connection: Upgrade Sec-Websocket-Key: BASE-64编码(randomly selected 16-byte value) Origin: cross-origin check Sec-Websocket-Protocal: chat,superchat //客户端希望使用的协议,one or more comma-separated subprotocol the client wishes to speak, ordered by preference Sec-Websocket-Version: 13(must be)

回复: HTTP/1.1 101 Switching Protocals //协议转换 Upgrade: websocket Connection: Upgrade Sec-Websocket-Accept: BASE-64编码(SHA-1加密(Sec-Websocket-Key==GUID(Globally Unique Identifier)("258EAFA5-E914-47DA-95CA-C5AB0DC85B11"))) Sec-Websocket-protocal: chat

传送数据:文本、二进制、控制帧等

handshake and then data transfer

基于TCP的独立协议;

由http server解析握手连接(Upgrade request) 80 443

ws-URI = "ws:" "//" host [ ":" port ] path [ "?" query ] wss-URI = "wss:" "//" host [ ":" port ] path [ "?" query ]

host = <host, defined in [RFC3986], Section 3.2.2> port = <port, defined in [RFC3986], Section 3.2.3> path = <path-abempty, defined in [RFC3986], Section 3.3> query = <query, defined in [RFC3986], Section 3.4>

if the client is a web browser, it supplies /origin/.

数据传输:一连串的帧(frames)

二进制:

协议:

|Opcode | Meaning | Reference | -+--------+-------------------------------------+-----------| | 0 | Continuation Frame | RFC 6455 | -+--------+-------------------------------------+-----------| | 1 | Text Frame | RFC 6455 | -+--------+-------------------------------------+-----------| | 2 | Binary Frame | RFC 6455 | -+--------+-------------------------------------+-----------| | 8 | Connection Close Frame | RFC 6455 | -+--------+-------------------------------------+-----------| | 9 | Ping Frame | RFC 6455 | -+--------+-------------------------------------+-----------| | 10 | Pong Frame | RFC 6455 | -+--------+-------------------------------------+-----------|

fin:标识消息的最后一部分 opcode:消息体说明

  • %x0 denotes a continuation frame
  • %x1 denotes a text frame
  • %x2 denotes a binary frame
  • %x3-7 are reserved for further non-control frames
  • %x8 denotes a connection close
  • %x9 denotes a ping
  • %xA denotes a pong
  • %xB-F are reserved for further control frames

    mask: 1 masked,0 unmasked

    当为1时,mask-key赋值,用于服务器端 unmask payload data

    客户端发送到服务端的数据都必须mask

    payload length:7 bits, 7+16 bits, or 7+64 bits

    7 bits:0-125 payload length

    7+16 bits:16-bit unsigned integer are the payload length

    7+64 bits:64-bit unsigned integer (the most significant bit MUST be 0) are the payload length

    The payload length is the length of the "Extension data" + the length of the "Application data".

    masking-key:0 | 4 bytes, chosen at random by the client,不影响payload data的数据长度

    payload data:Extension data + Application data

    数据分片:fragmentation:

    main purpose:允许在不缓存完整消息的情况下发送未知大小的消息。使用数据分片,服务器或者中间媒介可以选择一个合适大小的缓存,来缓存及发送fragment

    sub:multiplexing,多路分发,

    Control frames MAY be injected in the middle of a fragmented message. Control frames themselves MUST NOT be fragmented.

    delivered in the order send by the sender

    不同消息不允许交叉存取分片

    基本传输结构:

    A fragmented message consists of a single frame with the FIN bit clear and an opcode other than 0, followed by zero or more frames with the FIN bit clear and the opcode set to 0, and terminated by a single frame with the FIN bit set and an pcode of 0.

    control frames:

    0x8 (Close), 0x9 (Ping), 0xA (Pong), 0xB-0xF reserved

    communicate state with websocket

    can be interjected in the middle of a fragmented message: 减少因为大体量消息控制帧的延迟

    payload length < 125

    must not be fragmented

    连接断开 close frame:

    客户端发送close frame

    客户端等待服务端断开连接,

    当服务端收到close frame, 会等待消息发送完毕再返回close frame

    服务端立即断开tcp连接,

    客户端可以在任何时刻关闭连接。

    ping frame: opcode---0x9 serve as a keepalive or as means to verify remote endpoint

    pong frame:opcode---0xA

    必须包含对应ping的 Application data

    回复最近的 ping frame

    可能的服务器端单向主动的pong frame,不需要回复。

    data frame:

    opcode---0x1:text data encoded as UTF-8

    opcode---0x2:binary

    websocket 可以使用任何http使用的安全验证方式。

    websocket机密性和完整性通过使用 websocket protocal over tls 即 wss

    底层网络协议,

    倾向于使浏览器成为一个与操作系统相仿的应用程序平台。

    低级网络API无法处理源安全模型。

    实时通讯;支持二进制和字符串传输。

    SPDY:扩充了Http,通过压缩http首部标识和多路复用,工作管道等手段改进http请求性能。改进网页性能。http的修改形式,修改了许多http非本质问题,

    Websocket API是完全事件驱动的,自动发送数据和通知。遵循异步编程模式。监听事件。open message error close。String Blob ArrayBuffer var blob = new Blob("blob data"); ws.send(blob); var array = new Unit8Array([2,3,4,5,6]); ws.send(array.buffer);

    readyState

websocket send()时立即生效的,但是浏览器对于发送的数据会进行缓存;使用bufferedAmount检查已经进入队列但是尚未发送到服务器的字节数,不包括协议帧组或者操作系统,网络硬件所进行的缓存。

关闭前检查bufferedAmount是否有为发送数据。

传输层协议。

websocket pingpong机制,保持连接存活。

Docker 基础入门
Hadoop 基础入门
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }