什么是 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月前
|
缓存 应用服务中间件 网络安全
Nginx中配置HTTP2协议的方法
Nginx中配置HTTP2协议的方法
135 7
|
16天前
|
域名解析 缓存 网络协议
Web基础与HTTP协议
通过掌握这些基础知识和技术,开发者可以更加高效地构建和优化Web应用,提供更好的用户体验和系统性能。
65 15
|
11天前
|
前端开发 网络协议 安全
【网络原理】——HTTP协议、fiddler抓包
HTTP超文本传输,HTML,fiddler抓包,URL,urlencode,HTTP首行方法,GET方法,POST方法
|
14天前
|
缓存 网络协议 算法
从零开始掌握HTTP协议
本文介绍HTTP协议的演变,从HTTP1.0到HTTP2.0。HTTP1.0为无状态连接,每次请求独立;HTTP1.1引入持久连接、管道化请求和更多状态码;HTTP2.0采用二进制分帧、多路复用、头部压缩及服务器主动推送,大幅提升性能与用户体验。了解这些区别有助于开发者优化应用和服务。
|
14天前
|
网络协议 安全 网络安全
探索网络模型与协议:从OSI到HTTPs的原理解析
OSI七层网络模型和TCP/IP四层模型是理解和设计计算机网络的框架。OSI模型包括物理层、数据链路层、网络层、传输层、会话层、表示层和应用层,而TCP/IP模型则简化为链路层、网络层、传输层和 HTTPS协议基于HTTP并通过TLS/SSL加密数据,确保安全传输。其连接过程涉及TCP三次握手、SSL证书验证、对称密钥交换等步骤,以保障通信的安全性和完整性。数字信封技术使用非对称加密和数字证书确保数据的机密性和身份认证。 浏览器通过Https访问网站的过程包括输入网址、DNS解析、建立TCP连接、发送HTTPS请求、接收响应、验证证书和解析网页内容等步骤,确保用户与服务器之间的安全通信。
62 1
|
2月前
|
开发者
HTTP 协议请求方法的发展历程
【10月更文挑战第21天】
|
2月前
|
Dubbo 安全 应用服务中间件
Apache Dubbo 正式发布 HTTP/3 版本 RPC 协议,弱网效率提升 6 倍
在 Apache Dubbo 3.3.0 版本之后,官方推出了全新升级的 Triple X 协议,全面支持 HTTP/1、HTTP/2 和 HTTP/3 协议。本文将围绕 Triple 协议对 HTTP/3 的支持进行详细阐述,包括其设计目标、实际应用案例、性能测试结果以及源码架构分析等内容。
195 10
|
2月前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
75 11
|
2月前
|
缓存 安全 网络协议
HTTPS协议的历史发展
HTTPS协议的历史发展
50 8
|
2月前
|
安全 应用服务中间件 Linux
判断一个网站是否使用HTTPS协议
判断一个网站是否使用HTTPS协议
97 4