iOS Developer技术文我爱编程

网络那点事 —— HTTP

2016-08-24  本文已影响211人  KentonYu

接下来你将会花费 10 分钟左右了解到如下内容:

  1. HTTP 的来世今生
  2. HTTPS 简介
  3. HTTP 请求方法介绍
  4. 常见复用连接方案

HTTP 的来世今生

HTTP(超文本传输协议),是应用最广泛的一种应用层网络协议,建立在 TCP/IP 协议簇之上,默认端口 80。目前位置一共有 4 个版本,分别是:HTTP/0.9,HTTP/1.0,HTTP/1.1,HTTP/2。其中 HTTP/0.9 版本(已过时)比较特殊,它只接受 GET 的请求方法,在请求中不指定版本号,且没有请求头。其之后的三个版本,目前都在广泛应用(HTTP/2 目前还未得到广泛普及)。接下来就一一介绍下目前在使用的三个版本的异同。

HTTP/1.0

HTTP/1.0 是第一个在请求中指定版本号的协议版本,目前主要应用在代理服务器中。支持 GET、POST、HEAD 三种请求方法。

HTTP/1.1

HTTP/1.1 继承了 HTTP/1.0 的优点,并对 HTTP/1.0 进行了性能上的优化,以及功能的扩展。主要体现在以下几点:

  1. 增加 Host 域
    HTTP/1.0 默认每台服务器绑定一个 IP,因此请求中只有 URI,不带 Host (可能认为建立 TCP 连接的时候指定了 IP 地址,这个 IP 已经指定了一个 Host)。但随着技术发展,一台服务器上可以部署多个服务站点并且共享一个 IP,因此 HTTP/1.1 在请求头中添加了 Host 字段(字段值可以为空,但字段缺失会报告错误,400 Bad Request)。
  2. 多路复用(MultiPlexing)
    多路复用即连接共享,二进制格式中的 Stream ID 就是用在多路复用的。一个 Request 对应一个 Stream 并分配一个 ID,这样一个连接上可以有多个 Stream,每个 Stream 的 Frame 可以随机的混合在一起,接收方可以根据 Stream ID 将 Frame 再整合到不同的 Request 里。
    连接共享会造成某些关键请求会被阻塞,因此提供了优先级(Priority)和请求依赖(Dependency)的机制。通过这两个机制,优先级高或者被依赖的 Stream 会被 Server 优先处理并响应。
  3. Request Header 压缩和缓存
    HTTP/1.x 的 Header 由于 Cookie 和 User Agent 体积容易膨胀,而且每次请求都会重新发送,因此 HTTP/2 压缩 Header 的同时,服务端和客户端都会缓存一份 Request Header 表,这样既减少了体积,还避免了相同的 Header 重复发送。
  4. Server Push
    HTTP/2.0 允许通过服务端推送的方式将客户端需要的内容预先推送过去。比如在用户第一次打开网站首页的时候,将必须资源主动推送到客户端,这样可以极大的提升用户体验。

HTTP 请求方法介绍

GET

GET,幂等操作,请求会显式地请求指定的资源。一般来说 GET 方法应该只用于数据的读取。之前一直以为 GET 在 HTTP 协议中有请求长度的限制,其实 HTTP 协议并没有规定具体的长度,具体长度是由浏览器或服务器决定和设置的。

HEAD

HEAD,请求指定的资源,但是服务端响应 HEAD 请求时不会回传具体的内容(Body)。

POST

POST,非幂等操作,请求会向指定资源提交数据(数据包含在Request Body 中),请求服务器进行处理。如:表单处理,文件上传等。

PUT

PUT,幂等操作,请求会向指定资源位置上传最新的内容(更新资源)。

DELETE

DELETE,幂等操作,请求服务器删除 URI 标识的资源。

CONNECT

CONNECT,HTTP/1.1协议预留的,能够将连接改为管道方式的代理服务器。通常用于SSL加密服务器的链接与非加密的HTTP代理服务器的通信。

OPTIONS

OPTIONS,返回 URI 标识资源所支持的所有 HTTP 请求方法。类似 HEAD ,也可以通过发送 OPTIONS 请求判断是否有权限请求该资源。

TRACE

TRACE,服务器返回收到的请求信息,该方法主要用户 HTTP 请求的测试和诊断。

PATCH

PATCH, 在 2010 年 RFC 5789 标准中被定义。与 PUT 请求类似,用于资源的更新,但是有两点不同:

  1. PATCH 一般用于资源的部分更新,而 PUT 一般用于资源整体的更新;
  2. 当资源不存在时,PATCH 会创建一个新的资源,而 PUT 只会对已有的资源进行更新。

HTTPS

HTTPS(Hypertext Transfer Protocol Secure)是一种网络安全传输协议。HTTPS 经过 HTTP 进行通信,但是利用 SSL/TLS 来对数据包进行加密,默认端口 443。HTTPS 可以防止攻击者抓包,中间人攻击等(调试 HTTPS 接口时,可以通过给 Charles 配置 HTTPS 私钥来进行抓包)。

TLS/SSL

TLS(传输层安全协议,Transport Layer Security)是一种安全协议,前身是 SSL(安全套接层,Secure Sockets Layer)。

工作原理

详见SSL/TLS协议运行机制的概述


常见复用连接方案

虽然 HTTP/1.x 可以通过设置 Connection:Keep-Alive,但是只能在一段时间里复用该连接,具体时间由服务器控制。这对浏览器端的体验提升比较大,因为请求基本集中在页面刷新那几秒里。但是相对于 App 端,优化的体验并不是很有效果,App 端的请求较为分散,而且时间跨度上一般比较长(服务器端默认连接保持时间 15s 左右)。因此 App 端一般只能从应用层寻找其他解决方案。

TCP 长连接

基于 TCP 协议建立长连接通道。但是 TCP 的 Socket 编程技术难度相对复杂很多,而且需要自己制定协议。当然,这样做带来的收益也很明显,信息的传递实时性以及并发请求量对服务器的压力都将得到很好的解决(普通 HTTP 连接在高并发的情况下,频繁创建/销毁连接对资源消耗很大)。

HTTP long-polling

客户端发送一个 polling 请求到服务器,服务器只有产生新的数据时才会返回数据,不然这个连接会一直保持住。当服务器数据返回后,客户端又将会重新发送一个 polling 请求,如此循环。
long-polling 方式每次接收到数据都会重新发起一个相同的请求,因此每次都会带上 Header 以及不能向服务器发送数据,数据通道是单项的,主动权是在服务器。

HTTP streaming

和 HTTP long-polling 相比,最大的不同在于 streaming 方式在服务端响应了数据之后,并不会断开这个连接,而是持续的通过这个通道传输数据给客户端(显然是单项数据通道,并且不会重复发送 Header 数据)。streaming 利用的就是 HTTP/1.1 的 Transfer Encoding ,通过在 Response 里设置 Transfer Encoding: chunked 告诉客户端后续还有数据,不要中断连接。

WebSocket

WebSocket 和 TCP 长连接相似,基于 TCP 协议,有双向的数据通道。WebSocket 的优势在于提供了 Message 的概念,而不是 TCP 长连接的基于字节流。但是 Web Socket 在 2010 年才起草,相对来说还比较新,不过新的浏览器都是支持的。Nodejs 中的 Socket.IO 就是基于 WebSocket 实现的,但是同时还支持 Adobe Flash Socket、AJAX 长轮询、AJAX multipart streaming、持久Iframe、JSONP轮询等。Socket.IO 能够根据浏览器对通讯机制的支持情况自动地选择最佳的方式来实现网络实时应用。


结束语

文中如有错误,望能指出。以上这些基本都是对网络基础的一个回顾和整理,但是在这个过程中也补了很多洞,当然很多内容都没有深入去分析、实战,也有一些必要的知识点没有提及,希望大家能指出。
最后的最后,希望大家轻按下方二维码,关注 He 码 🚀🚀 —— 一群年幼无知的码农 boy 的日记 !

Reference

上一篇下一篇

猜你喜欢

热点阅读