最近公司内部同事分享了WebSocket相关的一些知识,之前也用过WebSocket做过一个即时通信的应用。基本上但凡提到WebSocket和HTTP的关系都会有以下两条:

  1. WebSocket和HTTP都是基于TCP协议的两个不同的协议

  2. WebSocket依赖于HTTP连接

作为结论性的总结,直接了当,但是我需要更多的实现细节来解释上述结论。因为都是基于TCP的两个独立的协议,WebSocket按理说可以和HTTP没有关系,所以这里面包含两个问题:

  1. WebSocket依赖于HTTP连接,那么它如何从连接的HTTP协议转化为WebSocket协议?

  2. WebSocket为什么要依赖于HTTP协议的连接?

问题一

幸运的是,第一个问题的答案很容易找到。

每个WebSocket连接都始于一个HTTP请求。具体来说,WebSocket协议在第一次握手连接时,通过HTTP协议在传送WebSocket支持的版本号,协议的字版本号,原始地址,主机地址等等一些列字段给服务器端:

GET /chat HTTP/1.1
Host: server.example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key:dGhlIHNhbXBsZSBub25jZQ==
Origin: http://example.com
Sec-WebSocket-Version: 13

注意,关键的地方是,这里面有个Upgrade首部,用来把当前的HTTP请求升级到WebSocket协议,这是HTTP协议本身的内容,是为了扩展支持其他的通讯协议。如果服务器支持新的协议,则必须返回101:

HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept:s3pPLMBiTxaQ9kYGzzhZRbK+xOo=

至此,HTTP请求物尽其用,如果成功出发onopen事件,否则触发onerror事件,后面的传输则不再依赖HTTP协议。总结一下,这张图比较贴切:

WebSocket and HTTP

问题二

经过学习和理解,我认为有两点:

第一,WebSocket设计上就是天生为HTTP增强通信(全双工通信等),所以在HTTP协议连接的基础上是很自然的一件事,并因此而能获得HTTP的诸多便利。第二,这诸多便利中有一条很重要,基于HTTP连接将获得最大的一个兼容支持,比如即使服务器不支持WebSocket也能建立HTTP通信,只不过返回的是onerror而已,这显然比服务器无响应要好的多。

最后

关于WebSocket和HTTP的讨论其实网上并不少,但因为一些资料本身就逻辑混乱,往往看的越多可能对于它们的关系越糊涂。理清一下这个简单的关系对于了解它们的应用场景还是有必要的,这也是我做这个分析的出发点所在。

理清 WebSocket 和 HTTP 的关系相关推荐

  1. java websocket_理清 WebSocket 和 HTTP 的关系

    问题一 问题二 最后 <Netty 实现原理与源码解析 -- 精品合集> <Spring 实现原理与源码解析 -- 精品合集> <MyBatis 实现原理与源码解析 -- ...

  2. 帮你理清 SpringBoot 与 SpringMVC 的关系

    spring boot就是一个大框架里面包含了许许多多的东西,其中spring就是最核心的内容之一,当然就包含spring mvc.spring mvc 只是spring 处理web层请求的一个模块. ...

  3. 教你理清SpringBoot与SpringMVC的关系

    spring boot就是一个大框架里面包含了许许多多的东西,其中spring就是最核心的内容之一,当然就包含spring mvc.spring mvc 是只是spring 处理web层请求的一个模块 ...

  4. linux系统解锁用户百度,详细到没朋友,一文帮你理清Linux 用户与用户组关系~

    原标题:详细到没朋友,一文帮你理清Linux 用户与用户组关系~ 1.用户和用户组文件 在 linux 中,用户帐号,用户密码,用户组信息和用户组密码均是存放在不同的配置文件中的. 在 linux 系 ...

  5. 详细到没朋友,一文帮你理清Linux 用户与用户组关系~

    引用自:https://mp.weixin.qq.com/s/Fl8ZjaUQuLDx7jbgM-1T5w 1.用户和用户组文件 在 linux 中,用户帐号,用户密码,用户组信息和用户组密码均是存放 ...

  6. linux转为root用户_详细到没朋友,一文帮你理清Linux 用户与用户组关系~

    1.用户和用户组文件 在 linux 中,用户帐号,用户密码,用户组信息和用户组密码均是存放在不同的配置文件中的. 在 linux 系统中,所创建的用户帐号和其相关信息 (密码除外) 均是存放在 / ...

  7. 如何快速理清并绘制复杂人物关系图

    两个主要方法:分类法.代际法(两种方法经常会结合着使用),基本能够把每个故事里的复杂人物关系厘清. 01 分类法 简单来说,就是把相同阵营/家庭/组织的人物归类到一起.这么说可能还是有点抽象,下面以题 ...

  8. Swoole的TCP/IP HTTP WebSocket关系

    1.网络分层层级 2.ws的由来 我们知道HTTP是为了规范HTML页面的发布.接收而提出的. 为了规范HTML5,WebSocket协议提出了. 3.长轮训短轮询 短轮询的方式是:页面定时向服务器发 ...

  9. js websocket同步等待_WebSocket硬核入门:200行代码,教你徒手撸一个WebSocket服务器...

    本文原题"Node.js - 200 多行代码实现 Websocket 协议",为了提升内容品质,有较大修订. 1.引言 最近正在研究 WebSocket 相关的知识,想着如何能自 ...

最新文章

  1. 函数声明(函数原型)的一些关键技巧
  2. 独家!扒出腾讯新高管余总的真面目!
  3. 网页常用动态效果--悬浮广告
  4. c语言只能最大值不能最小值,用c语言编写输入10个无序的整数,去掉一个最大值和最小值,然后求其平均值...
  5. 数据科学 IPython 笔记本 8.11 多个子图
  6. 【MySQL】Path does not chain with any of the trust anchors
  7. Splice Beatmaker for Mac(音乐节拍工具)
  8. HashMap死循环讲解(JDK1.8 之前)
  9. 如何把门禁卡做成你用不起的样子?B站up主自制迷你卡片,公司小区通刷,还带墨水屏的那种...
  10. mysql 中电话号码_类型-电话号码和地址的mysql数据类型
  11. 3DMax、Unity、Threejs旋转转换
  12. SAP中销售订单计划行类别与移动类型关系配置分析
  13. 2010最新网络语言
  14. 【jzoj5335】早苗
  15. linux reedme常用单词,【每天打卡记单词】高中英语必背单词3500(Q/R)
  16. 如何构建Birt报表应用程序?
  17. 三国群英传M玩亚服好还是台服好?服务器选择推荐
  18. cc1101初始化c语言程序,STC89C52单片机驱动CC1101无线模块的发送C语言程序
  19. [Crypto]ECB模式攻击
  20. nginx学习--nginx下的gzip与vary、预压缩、缓存、反向代理的结合

热门文章

  1. 大话设计模式(七 工厂不好用了?)
  2. simple-android-flux,深入浅出Flux
  3. 【前端Talkking】CSS系列-css3之box-shadow介绍
  4. hdu 6034 B - Balala Power! 贪心
  5. RIS镜像中添加网卡和RAID卡驱动方法及实践经验总结
  6. 你不是在拯救世界就是在拯救世界的路上
  7. matlab中怎么求矩阵的特征值和特征向量
  8. Anaconda建立新的环境,出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url 解决过程
  9. AWGN和Rayleigh信道下QPSK的误码率分析
  10. ELS多种方式集群部署