什么是 HTTP 协议?

简介: HTTP 协议不用我多说了吧,大家都知道,现在我 web 开发一般都是使用 HTTP 协议来进行通信的。到目前为止,HTTP 进行了几次版本更新,HTTP 1.1 就是表示HTTP 的 1.1 版本。1.1 版本也是目前大部分网站所用的版本。

网络异常,图片无法展示
|

版本介绍


HTTP 协议不用我多说了吧,大家都知道,现在我 web 开发一般都是使用 HTTP 协议来进行通信的。到目前为止,HTTP 进行了几次版本更新,HTTP 1.1 就是表示HTTP 的 1.1 版本。1.1 版本也是目前大部分网站所用的版本。

HTTP 0.9

  • 发布时间:1991 年
  • 简介:梦开始的地方,只接受GET一种请求方法,没有在通讯中指定版本号,且不支持请求头。由于该版本不支持POST方法,因此客户端无法向服务器传递太多信息。

HTTP 1.0

  • 发布时间:1996 年 5 月
  • 简介:这是第一个在通讯中指定版本号的HTTP协议版本。同时比 0.9 版本增加大量新特性。非持续连接,每次都要重新与服务器建立连接。

HTTP 1.1

  • 发布时间:1997 年1月
  • 简介:默认采用持续连接(Connection: keep-alive),能很好地配合代理服务器工作。还支持以管道方式在同时发送多个请求,以便降低线路负载,提高传输速度。同时这也是目前最流行的版本。

HTTP/1.1相较于HTTP/1.0协议的区别主要体现在:

  • 缓存处理
  • 带宽优化及网络连接的使用
  • 错误通知的管理
  • 消息在网络中的发送
  • 互联网地址的维护
  • 安全性及完整性

HTTP 2.0

  • 发布时间:2015 年 5 月
  • 简介:HTTP/2 是 HTTP 协议自 1999 年 HTTP 1.1 的改进版 RFC 2616 发布后的首个更新,主要基于 SPDY 协议。它由互联网工程任务组(IETF)的Hypertext Transfer Protocol Bis(httpbis)工作小组进行开发。该组织于 2014 年 12 月将 HTTP/2 标准提议递交至 IESG 进行讨论,于 2015 年 2 月 17 日被批准。

报文格式


请求报文

请求报文分为 4 个部分,分别是请求行、请求头、换行行、请求数据,每个部分的末尾都会带上回车符(CR,ASCII:0d)和换行符(LF,ASCII:0a)

其中请求行分为请求方法、请求的 URL 地址、HTTP 版本号,每个字段用空格(ASCII:20)来分隔

请求头部分可以有多行,每行用回车符和换行符区分

网络异常,图片无法展示
|

为了方便理解,我们可以用 Wireshark 来抓取一个 HTTP 请求来看看,并把它和上图进行关联

网络异常,图片无法展示
|

响应报文

响应报文和请求报文基本差不多,唯一有区别就第一行状态行和请求报文的第一行请求行有区别。

状态行也分为三个部分,分别是 HTTP 版本、状态码、状态码描述,每个部分用空格进行分隔。

响应头和请求头一样,可以有多行

网络异常,图片无法展示
|

同样,用 Wireshark 抓取一个响应报文,来和上图进行一一对应。

网络异常,图片无法展示
|

持续连接和非持续连接

上面说了,HTTP 1.1 的连接由原来的非持续连接变为了持续连接(Connection: keep-alive)。那么这两个有什么区别呢?

非持续连接指的是当向服务器多次请求资源时,每次都需要单独的进行 TCP 的连接和断开。

持续连接指的是当向服务器请求资源时,可以共用一个 TCP 连接来进行资源的传输。

尽管 HTTP 1.1 默认使用持续连接,但是也可以配置为非持续连接,设置方法:Connection 字段设置为 close

为了好理解,为画了一张图,图中省略了 TCP 建立连接和断开连接的细致步骤。

网络异常,图片无法展示
|

请求方法

一般我们常用的只有 GET 和 POST 两个请求方法,但是如果遵循 REST 风格来进行 API 接口的设计,就可以用到下面的一些请求方法了。

  • OPTIONS:这个方法会请求服务器返回该资源所支持的所有HTTP请求方法
  • GET:获取指定资源地址的数据,不推荐进行上传数据等操作。
  • HEAD:服务器在响应 HEAD 请求时不会回传 Body 资源的内容部分,这样,我们可以不传输全部内容的情况下,就可以获取服务器的响应头信息。
  • POST:POST 请求会 向指定资源提交数据,请求服务器进行处理,请求数据会被包含在请求体中。
  • PUT:可以将指定资源的最新数据传送给服务器取代指定的资源的内容。
  • DELETE:删除指定资源的数据。
  • TRACE:TRACE 请求服务器回显其收到的请求信息,该方法主要用于 HTTP 请求的测试或诊断。
  • ......

响应码


1xx

Informational(信息性状态码),表示接收的请求正在处理,具体可以查看 RFC 文档

2xx

Success(成功状态码),请求正常处理完毕,具体可以查看 RFC 文档

3xx

Redirection(重定向状态码),需要进行附加操作以完成请求,具体可以查看 RFC 文档

4xx

Client Error(客户端错误状态码),服务器无法处理请求,具体可以查看 RFC 文档

5xx

Server Error(服务器错误状态码),服务器处理请求出错,具体可以查看 RFC 文档

目录
相关文章
|
2月前
|
数据采集 存储 JSON
从零到一构建网络爬虫帝国:HTTP协议+Python requests库深度解析
【7月更文挑战第31天】在网络数据的海洋中,使用Python的`requests`库构建网络爬虫就像探索未知的航船。HTTP协议指导爬虫与服务器交流,收集信息。HTTP请求包括请求行、头和体,响应则含状态行、头和体。`requests`简化了发送各种HTTP请求的过程。
61 4
|
9天前
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
文章介绍了如何配置HAProxy以支持HTTPS协议和实现服务器的动态上下线。
38 8
HAProxy的高级配置选项-配置haproxy支持https协议及服务器动态上下线
|
14天前
|
安全 Java Shell
【内网—内网转发】——http协议代理转发_reGeorg代理转发
【内网—内网转发】——http协议代理转发_reGeorg代理转发
15 3
|
24天前
|
存储 网络协议 安全
HTTP协议和运行原理
HTTP协议和运行原理
|
1月前
|
域名解析 缓存 网络协议
揭秘DNS协议:从'http://www.example.com'到IP地址的奇幻旅程,你不可不知的互联网幕后英雄!
【8月更文挑战第4天】在互联网的广袤空间里,每台设备都有唯一的IP地址,但记忆这些数字组合并不直观。因此,DNS(域名系统)作为关键桥梁出现,将易记的域名转换为IP地址。DNS协议工作于应用层,支持用户通过域名访问资源。DNS系统包含多级服务器,从根服务器到权威服务器,共同完成域名解析。查询过程始于客户端,经过递归或迭代查询,最终由权威服务器返回IP地址,使浏览器能加载目标网页。
73 12
|
1月前
|
安全 算法 网络协议
【在Linux世界中追寻伟大的One Piece】HTTPS协议原理
【在Linux世界中追寻伟大的One Piece】HTTPS协议原理
37 2
|
1月前
|
网络协议
Web基础与HTTP协议
【8月更文挑战第10天】
33 2
|
1月前
|
API 开发者 微服务
RPC和 HTTP协议
【8月更文挑战第8天】RPC(远程过程调用)使程序能像本地调用般请求远程服务,简化网络通信细节。其优点包括高效的数据传输及严格的类型定义,适合微服务间的高效通信。HTTP(超文本传输协议)则是用于万维网数据传输的通用协议,以文本为基础,易于理解和调试,并被广泛支持。两者各有侧重,RPC偏高速服务通信,HTTP则更适用于多样化的网络场景。选择时需根据具体需求决定。
|
2月前
|
缓存 网络协议 算法
(二)Java网络编程之爆肝HTTP、HTTPS、TLS协议及对称与非对称加密原理!
作为一名程序员,尤其是Java程序员,那必须得了解并掌握HTTP/HTTPS相关知识。因为在如今计算机网络通信中,HTTP协议的作用功不可没,无论是日常上网追剧、冲���、亦或是接口开发、调用等,必然存在HTTP的“影子”在内。尤其对于WEB开发者而言,HTTP几乎是每天会打交道的东西。
59 10