WebSocket 原理

2018-07-26 10:40:17 +08:00
 jonychen1

今天来讲一下 WebSocket 的原理,能让你更深入的去了解 WebSocket,深知其原理,才能更好的去使用它。 WebSocket 是 HTML5 出的协议,也就是说 HTTP 协议没有变化,或者说没关系,但 HTTP 是不支持持久连接的(长连接,循环连接的不算)。 首先 HTTP 有 1.1 和 1.0 之说,也就是所谓的 keep-alive,把多个 HTTP 请求合并为一个,但是 Websocket 其实是一个新协议,跟 HTTP 协议基本没有关系,只是为了兼容现有浏览器的握手规范而已,也就是说它是 HTTP 协议上的一种补充。有交集,但是并不是全部。 另外 Html5 是指的一系列新的 API,或者说新规范,新技术。Http 协议本身只有 1.0 和 1.1,而且跟 Html 本身没有直接关系。通俗来说,你可以用 HTTP 协议传输非 Html 数据,就是这样。再简单来说,层级不一样。 WebSocket 的协议是持久化的,而 HTTP 是非持久化的协议。 首先我们来看个典型的 Websocket 握手 GET /chat HTTP/1.1 Host: server.example.com Upgrade: websocket Connection: Upgrade Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw== Sec-WebSocket-Protocol: chat, superchat Sec-WebSocket-Version: 13 Origin: http://example.com 这段类似 HTTP 协议的握手请求中,多了几个东西。我会顺便讲解下作用。 Upgrade: websocket Connection: Upgrade 这个就是 Websocket 的核心了,告诉 Apache、Nginx 等服务器:注意啦,我发起的是 Websocket 协议,快点帮我找到对应的助理处理。 Sec-WebSocket-Key: x3JJHMbDL1EzLkh9GBhXDw== Sec-WebSocket-Protocol: chat, superchat Sec-WebSocket-Version: 13 首先,Sec-WebSocket-Key 是一个 Base64 encode 的值,这个是浏览器随机生成的,告诉服务器:验证是不是真的是 Websocke t 助理。 然后,Sec_WebSocket-Protocol 是一个用户定义的字符串,用来区分同 URL 下,不同的服务所需要的协议。 最后,Sec-WebSocket-Version 是告诉服务器所使用的 Websocket Draft (协议版本)。 然后服务器会返回下列东西,表示已经接受到请求, 成功建立 Websocket 啦! HTTP/1.1 101 Switching Protocols Upgrade: websocket Connection: Upgrade Sec-WebSocket-Accept:HSmrc0sMlYUkAGmm5OPpG2HaGWk= Sec-WebSocket-Protocol: chat 这里开始就是 HTTP 最后负责的区域了,告诉客户端已经成功切换协议 Upgrade: websocket Connection: Upgrade 依然是固定的,告诉客户端即将升级的是 Websocket 协议,而不是 mozillasocket,lurnarsocket 或者 shitsocket。 然后,Sec-WebSocket-Accept 这个则是经过服务器确认,并且加密过后的 Sec-WebSocket-Key。 服务器:返回 ID CARD 来证明。 后面的,Sec-WebSocket-Protocol 则是表示最终使用的协议。 至此,HTTP 已经完成它所有工作了,接下来就是完全按照 Websocket 协议进行了。具体的协议就不在这阐述了。 关注 GoEasy WebSocket 简单开发不迷路。

1199 次点击
所在节点   2018
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/474273

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX