前端Web前端之路让前端飞

浅析HTTP、HTTP1.0、HTTP1.1、HTTP2.0、H

2017-11-12  本文已影响170人  Wendy曹
image.png

最近在啃《HTTP权威指南》,该书有多优秀众所周知啊,光看不写假把式,所以打算看书期间整理几篇相关的文章。

一、HTTP

HTTP(超文本传输协议,HyperText Transfer Protocol)是应用层的协议,目前在互联网中应用广泛。

它被设计用于Web浏览器和Web服务器之间的通信,但它也可以用于其他目的。 HTTP遵循经典的客户端-服务端模型
,客户端打开一个连接以发出请求,然后等待它收到服务器端响应。 HTTP是
无状态协议,意味着服务器不会在两个请求之间保留任何数据(状态)。

二、HTTP1.0 ——构建可扩展性

HTTP原有的应用非常局限,浏览器和服务器迅速扩展使其用途更广:

同时还开始支持一种被称为keep-alive连接的早期实验性持久连接,下图显示了keep-alive连接的一些性能优点,图中将在串行连接上实现4个HTTP事务的时间线与在一条持久连接上实现同样事务所需要的时间线进行了比较。由于去除了进行连接和关闭连接的开销,所以时间有所缩短。

compare.png

必须发送一个connection:Keep-Alive请求首部来激活keep-alive连接

三、HTTP1.1 ——标准化的协议

HTTP/1.0的多种不同的实现运用起来有些混乱,HTTP1.1是第一个标准化版本,重点关注的是校正HTTP设计中的结构性缺陷:

在http1.1中,client和server都是默认对方支持长链接的, 如果不希望使用长链接,则需要在header中指明connection:close;

四、HTTP2.0——为了更优异的表现

HTTP/2在HTTP/1.1有几处基本的不同:

五、HTTPS

HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全。为了保证这些隐私数据能加密传输,于是网景公司设计了SSL(Secure Sockets Layer)协议用于对HTTP协议传输的数据进行加密,从而就诞生了HTTPS。现在的HTTPS都是用的TLS协议,但是由于SSL出现的时间比较早,并且依旧被现在浏览器所支持,因此SSL依然是HTTPS的代名词。

image.png

HTTPS在传输数据之前需要客户端(浏览器)与服务端(网站)之间进行一次握手,在握手过程中将确立双方加密传输数据的密码信息。TLS/SSL协议不仅仅是一套加密传输的协议,TLS/SSL中使用了非对称加密,对称加密以及HASH算法。

最后建议大家也去看看《http权威指南》,虽然可能很多地方都看不懂,但是第一遍可以大致翻阅一下,对知识点有个全局了解,等实践中遇到问题之后再查看。

上一篇 下一篇

猜你喜欢

热点阅读