三歪熬夜写了一篇HTTP总结

Java3y

共 3087字,需浏览 7分钟

 ·

2020-04-22 23:21


还记得我当时学习的时候,HTTP就只有三个版本,分别是HTTP1.0HTTP1.1HTTP/2

现在回过头看HTTP/3也出了有一年多的时间了。

49d41817938b8475f1a5496665488542.webp

在我眼里,我觉得HTTP/3还是一个很新的东西,还没这么快落地,但可以去了解一波。毕竟已经是2018年就出来的东西了,现在已经是2020年了。

https://www.zhihu.com/question/302412059

Quic(QuickUDP Internet Connections)是一种新的传输方式,与TCP相比,它减少了延迟。表面上,Quic非常类似于在UDP上实现的TCP+TLS+HTTP/2

3907615692569f713070fae4900cd67f.webp

这篇文章也不是来讲HTTP/3的,主要来回顾一下HTTP究竟有哪些知识点是值得注意和重点学习的,主要内容包括:

  • 什么是HTTP

  • HTTP各个版本的特点

  • HTTPS

HTTP电子书,有兴趣的同学可以浏览一波。共有「30」页

739438bef14515436258220c64a14658.webp

什么是HTTP

HTTP协议是客户端和服务器交互的一种通迅的格式

所谓的交互实际上就是「请求」和「响应」。三歪叫你一声(请求),你回复了三歪(响应),这就是「交互」。

所谓的「协议」实际上就是双方约定好的「格式」,让双方都能看得懂的东西而已。

我们学习HTTP的时候,最开始肯定学的是「请求」和「响应」的格式以及相关字段是怎么样的。

5f21d06bd53e6d997083a827af12c6c1.webp

貌似我们随便打开个网站,看下HTTP的请求和响应的信息都非常多,可能会觉得很难。(这么多的东西,谁记得住啊….)

一般的开发也不会完全记住里边的所有信息,这个是很正常的。不懂没关系,我们把对应的信息「复制粘贴」到搜索引擎,自然就有很多的教程「告诉」你,这个信息是什么意思。

所以,在初学的时候需要知道HTTP的请求和响应头原来是长这个样子的,理解「响应」和「请求」是什么意思,「猜测」客户端在请求的时候会把什么信息给服务器,服务器在响应的时候把什么信息给客户端。

0f8f2d0578c7d6c8febc8c3ae5d7ea1b.webp

在这个过程中,我们会学到Request Method这个字段,现在盛行的RESTful就是充分利用这个字段的「含义」

  • GET:请求资源

  • POST:创建资源

  • PUT:更新资源

  • DELETE:删除资源

c9cbe051d93e7a8d184387ef24e55c39.webp

也会学到Status Code这个字段,这个字段的返回值能很快定位出服务端「响应」给我们返回了什么状态,我们经常会用到这个状态值来判断这次的请求是否存在问题,如果存在问题可能是由什么原因造成的。

1278dae784bc03d9bb45ccf64c1083c4.webp

说白了,在初学HTTP的时候其实就是在学HTTP「请求」和「响应」的字段含义,这块也不用完全把所有的「字段」给记下来,只要用到的时候会知道查就OK了。

HTTP各个版本的特点

截止到目前为止,现在HTTP有以下的版本:

  • HTTP1.0

  • HTTP1.1

  • HTTP/2

  • HTTP/3

学习这些版本的时候,我们可以看看「新版本」的到底解决了什么问题。目前来说,大多数都是在使用HTTP 1.1HTTP/2

7fe72b6eeaf7ab3af1afcbe75829e5ba.webp9860ab76789ecfd0d4ed5cdd2a579811.webp

HTTP1.0默认是短连接,每次与服务器交互,都需要新开一个连接。

089705d7cfa1a44b08dbacaeeb873cbb.webp

HTTP1.1版本:

  • 最主要的是默认持久连接。只要客户端服务端任意一端没有明确提出断开TCP连接,就一直保持连接,可以发送多次HTTP请求。

  • 其次就是断点续传(Chunked transfer-coding)。利用HTTP消息头使用分块传输编码,将实体主体分块传输。

9c3e09843ba3a766d0df56176351e808.webp

HTTP/2版本:

  • HTTP1.1提出了管线化(pipelining)理论,但是默认都是关闭的。而HTTP/2允许同时通过单一的TCP连接发起多个的请求和响应消息

  • 不再以文本的方式传输,采用二进制分帧层,对头部进行了压缩,支持流的控制

e8dd33c330b8ba6d4468f1205489a0e5.webp

HTTP/3版本:

  • HTTP1.xHTTP/2底层都是TCP,而HTTP/3底层是UDP。使用HTTP/3能够减少RTT「往返时延」(TCP三次握手,TLS握手)

HTTPS

HTTP协议默认是「明文」的,那就是说,如果在交互的过程中被「挟持」了,那传输的信息会「暴露」或者「篡改

安全问题在网络上还是很重要的,现在大部分的网站都是用的HTTPS协议

6e6190b2a79f64e78c44536d8c8c3ba0.webp

HTTPS是基于TLS上实现的,我这里就不赘述对称和非对称加密的例子了。直接来看看HTTPS的过程是怎么样的。

首先,我们要认清一点:在网络上,只要是客户端和服务端在交互,那就有可能被挟持。而客户端是需要确切地知道服务端是不是真实的,所以我们需要CA(公信机构)来帮客户端认定服务端是真实的。

2732279ceaf307add52797b86df677ba.webp

服务端在使用HTTPS前,需要去认证的CA机构申请一份数字证书。数字证书里包含有证书持有者、证书有效期、服务器公钥等信息。

CA机构也有自己的一份公私钥,在发布数字证书之前,会用自己的私钥对这份数字证书进行加密。

等到客户端请求服务器的时候,服务端返回证书给客户端。

客户端用CA的公钥对证书解密(因为CA是工信机构,会内置到浏览器或操作系统中,所以客户端会有公钥)。这个时候,客户端会判断这个证书是否可信/有无被篡改

  • 解释:证书被CA机构的私钥解密,然后客户端用CA证书的公钥解密。这种私钥加密,公钥解密我们一般用来做数字签名(看有无被篡改)

客户端发现证书是可信,然后解密出服务器的公钥。客户端生成一个对称加密的随机Key,并用证书内的公钥进行加密,发送给服务端。

服务端收到消息,用自己的私钥解密,拿到客户端随机生成的Key,加密数据后返回给客户端。

客户端收到消息,就可以用之前生成的Key来解密服务端返回的数据了。

6437094bc9733eb7575c8bdccf17272e.webp

三歪再简单解释一下:

  1. 首先客户端跟服务器之间的交互,客户端需要知道服务端是不是真实的。因为客户端与服务端之间的通讯都有可能被「挟持」。所以需要有一个公信机构CA来让客户端知道服务端是真实的。

  2. CA机构将服务端的公钥信息用自己的私钥加密,客户端用CA机构的公钥解密。保证CA证书是没有被篡改,是真实的。

  3. 客户端拿到CA证书,就能解析到服务端的公钥。客户端生成一个Key作为对称加密的秘钥,用服务端的公钥加密传给服务端。

  4. 服务端用自己的私钥解密客户端的数据,得到对称加密的秘钥。

  5. 后续就可以通过对称加密的秘钥愉快发送/接收消息了。

39093785c7eb74ab50608ecff27a99f8.webp

总结

HTTP/2和HTTPS在面试的时候还是经常会考的,我在校招面试的时候就被问到过。如果对这两个知识点还不是很了解的同学,我建议得掌握起来。

现在已经工作有一段时间了,为什么还来写HTTP呢,原因有以下几个:

  • 我是一个对排版有追求的人,如果早期关注我的同学可能会发现,我的GitHub、文章导航的read.me会经常更换。现在的GitHub导航也不合我心意了(太长了),并且早期的文章,说实话排版也不太行,我决定重新搞一波。

  • 我的文章会分发好几个平台,但文章发完了可能就没人看了,并且图床很可能因为平台的防盗链就挂掉了。又因为有很多的读者问我:”你能不能把你的文章转成PDF啊?“

  • 我写过很多系列级的文章,这些文章就几乎不会有太大的改动了,就非常适合把它们给”持久化“。

基于上面的原因,我决定把我的系列文章汇总成一个PDF/HTML/WORD/epub文档。说实话,打造这么一个文档花了我不少的时间。为了防止白嫖,关注我的公众号回复「888」即可获取。

HTTP电子书,有兴趣的同学可以浏览一波。共有「30」页

a643629734ff3c30260216f4f919f52f.webp


 各类知识点总结

下面的文章都有对应的原创精美PDF,在持续更新中,可以来找我催更~

扫码或者微信搜Java3y 免费领取原创思维导图、精美PDF。在公众号回复「888」领取,PDF内容纯手打有任何不懂欢迎来问我。

原创电子书
ac80bbce9e9ce13630b1c5c5264fc037.webp

原创思维导图

bc96218c4bb3a77371306b034d243dbc.webp


c005955877cec9e35616bd88558a93f1.webp

461617499262fbe2fd9ef8f8218148b3.webp

461617499262fbe2fd9ef8f8218148b3.webp

浏览 36
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报