HTTP消息是什么
HTTP报文,又称为HTTP消息,是服务器和客户端之间交换数据的模块。有两种类型的消息︰请求,由客户端发送用来触发一个服务器上的动作;响应,来自服务器的应答。
HTTP消息由采用ASClI编码的多行文本构成。在HTTP/1.1及早期版本中,这些消息通过连接公开地发送。在HTTP/2中,为了优化和性能方面的改进,曾经可人工阅读的消息被分到多个HTTP帧中。
HTTP消息结构
HTTP请求消息和响应消息具有相似的结构,由以下部分组成︰
- start line:一行起始行用于描述要执行的请求,或者是对应的状态,成功或失败。这个起始行总
是单行的。 - HTTP headers:一个可选的HTTP头集合指明请求或描迹消息正文。
- empty line:一个空行指示所有关于请求的元数据已经发送完毕。
- body:一个可选的包含请求相关数据的正文(比如HTML表单内容),或者响应相关的文档。正文
的大小有起始行的HTTP头来指定。
起始行和HTTP消息中的HTTP头统称为“请求头”,而其有效负载被称为“消息正文”。
请求消息与响应消息
- HTTP请求消息:由客户端发送用来触发一个服务器上的动作。
- HTTP响应消息:来自服务器的应答。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wilzlX8N-1636689606615)(C:\Users\86175\Desktop\启嘉\Git\jody\HTTP\2.png)]
HTTP请求
起始行
起始行(start-line)包含三个元素:
- 请求方法:描述要执行的动作。例如GET表示要获取资源,POST表示向服务器推送数据。
- 请求地址:通常是一个URL,或者是协议、端口和域名的绝对路径。
- HTTP版本:定义了剩余报文的结构,作为对期望的响应版本的指示符。
GET/home.html HTTP/1.1
请求方法
HTTP协议定义了一组请求方法,以表明要对给定资源执行的操作,指示针对给定资源要执行的期望动作。
请求方法 | 描试 |
---|---|
GET | GET方法请求一个指定资源的表示形式。使用GET的请求应该只被用于获取数据 |
HEAD | HEAD方法请求一个与GET请求的响应相同的响应,但没有响应体 |
POST | POST方法用于将实体提交到指定的资源,通常导致状态或服务器上的副作用的更改 |
PUT | PUT方法用请求有效载荷替换目标资源的所有当前表示 |
DELETE | DELETE方法删除指定的资源 |
CONNECT | ONNECT方法建立一个到由目标资源标识的服务器的隧道 |
OPTIONS | OPTIONS方法用于描述目标资源的通信选项 |
TRACE | TRACE方法沿着到目标资源的路径执行一个消息环回测试 |
PATCH | PATCH方法用于对资源应用部分修改 |
请求头
请求头允许客户端向服务器端传递附加信息。请求头由名称(不区分大小写)后跟一个冒号“”,冒号后跟具体的值(不带换行符)组成。
根据不同上下文,可将请求头分为:
- 通用头:同时适用于请求和响应消息,但与最终消息主体中传输的数据无关的消息
- 请求头:包含更多有关要获取的资源或客户端本身信息的消息头。
- 实体头:包含有关实体主体的更多信息,比如主体长(Content-Length)度或其MIME类型。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DZ72gXbL-1636689606618)(C:\Users\86175\Desktop\启嘉\Git\jody\HTTP\3.png)]
请求主体
请求消息的最后一部分是请求主体。
- 不是所有的请求都需要请求主体:例如获取资源的请求GET、HEAD、DELETE和OPTIONS,通常它们不需要请求主体。
- 有些请求将数据发送到服务器以便更新数据:常见的的情况是POST请求(包含HTML表单数据)。
请求主体大致可分为两类:
- 单一资源主体:由一个单文件组成。该类型请求主体由两个header定义:Content-Type和Content-Lengtho
- 多资源主体:由多部分请求主体组成,每一部分包含不同的信息位。通常是和HTML表单连系在一起。
状态行
HTTP响应消息的起始行被称作状态行(status line),包含以下信息:
- 协议版本:通常为HTTP/1.1。
- 状态码:表明请求是成功或失败。常见的状态码是200,404,或302。
- 状态文本:一个简短的,纯粹的信息,通过状态码的文本描述,帮助人们理解该HTTP消息。
HTTP/1.1 200 OK
成功响应
状态码 | 描述 |
---|---|
200 OK | 请求成功 |
201 Created | 该请求已成功,并因此创建了一个新的资源。这通常是在PUT请求之后发送的响应 |
202 Accepted | 请求已经接收到,但还未响应,没有结果 |
lnformation | 定集合,而是来自本地或者第三方的拷贝 |
203Non-Authoritative | 服务器已成功处理了请求,但返回的实体头部元信息不是在原始服务器上有效的确 |
204 No Content | 服务器成功处理了请求,但不需要返回任何实体内容,并且希望返回更新了的元信息 |
205 Reset Content | 服务器成功处理了请求,且没有返回任何内容。该响应主要是被用于接受用户输入后,立即重置表单 |
206 Partial Content | 服务器已经成功处理了部分GET请求 |
重定向
状态码 | 描逑 |
---|---|
300 Multiple Choice | 被请求的资源有一系列可供选择的回馈信息 |
301MovedPermanently | 被请求的资源已永久移动到新位置 |
302 Found | 请求的资源现在临时从不同的URI响应请求 |
303 See Other | 对应当前请求的响应可以在另一个URI上被找到,而且客户端应当采用GET的方式访问那个资源 |
304 Not Modified | 如果客户端发送了一个带条件的 GET请求且该请求已被允许,而文档的内容(自上次访问以来或者根据请求的条件)并没有改变 |
客户端响
状态码 | 描述 |
---|---|
400 Bad Request | 语义有误,当前请求无法被服务器理解 |
401 Unauthorized | 当前请求需要用户验证 |
403 Forbidden | 服务器已经理解请求,但是拒绝执行它 |
404 Not Found | 请求失败,请求所希望得到的资源未被在服务器上发现 |
405 Method Not Allowed | 请求行中指定的请求方法不能被用于请求相应的资源 |
服务端响应
状态码 | 描述 |
---|---|
500 lnternal Server Error | 服务器遇到了不知道如何处理的情况 |
501 Not lmplemented | 此请求方法不被服务器支持且无法被处理 |
502 Bad Gateway | 此错误响应表明服务器作为网关需要得到一个处理这个请求的响应 |
503 Service Unavailable | 服务器没有准备好处理请求 |
504 Gateway Timeout | 当服务器作为网关,不能及时得到响应时返回此错误代码 |
505HTTP Version Not Supported | 服务器不支持请求中所使用的HTTP协议版本 |
HTTP响应
状态行
HTTP 响应的起始行被称作 状态行 (status line),包含以下信息:
- 协议版本,通常为
HTTP/1.1。
- 状态码 (**status code),表明请求是成功或失败。常见的状态码是
200
,404
,或302
。 - 状态文本 (status text)。一个简短的,纯粹的信息,通过状态码的文本描述,帮助人们理解该 HTTP 消息。
一个典型的状态行看起来像这样:HTTP/1.1 404 Not Found
。
响应头
响应的 HTTP headers遵循和任何其它 header 相同的结构:不区分大小写的字符串,紧跟着的冒号 (':'
) 和一个结构取决于 header 类型的值。 整个 header(包括其值)表现为单行形式。
有许多响应头可用,这些响应头可以分为几组:
- *General headers,*例如
Via
,适用于整个报文。 - *Response headers,*例如
Vary
和Accept-Ranges
,提供其它不符合状态行的关于服务器的信息。 - Entity headers,例如
Content-Length
,适用于请求的 body。显然,如果请求中没有任何 body,则不会发送这样的头文件。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IA6QlqeE-1636689606619)(C:\Users\86175\Desktop\启嘉\Git\jody\HTTP\4.png)]
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-QQiJmLZv-1636689606620)(C:\Users\86175\Desktop\启嘉\Git\jody\HTTP\5.png)]
响应主体
响应消息的最后一部分是响应主体。不是所有的响应都需要响应主体:例如具有状态码(如201或204)的响应,通常不会有响应主体。
响应主体大致可分为两类:
- 单一资源主体:由已知长度的单个文件组成。该类型响应主体由两个header定义
Content-Type
和Content-Lengtho
- 单一资源主体:由未知长度的单个文件组成,通过将
Transfer-Encoding
设置为chunked来使用chunks编码。 - 多资源主体:由多部分响应主体组成,每部分包含不同的信息段。但这是比较少见的。
MIME类型
MIME类型全称为Multipurpose Internet Mail Extensions,被译为多用途Internet邮件扩展类型,是一种标准化的方式来表示文档的性质和格式。
浏览器通常使用MIMVE类型(而不是文件扩展名)来确定如何处理文档;因此服务器设置正确以将正确的MIME类型附加到响应对象的头部是非常重要的。
类型 | 描述 | 经典示例 |
---|---|---|
text | 表明文件是普通文本 | text/plain, text/htmnl, text/css, text/iavascript |
image | 表明是某种图像 | image/gif, imag/png, imageljpeg, inage/bnp, image/webp |
audio | 表明是某种音频文件 | audio/midi, audio/mpeg, audio/webm, audio/ogg, audio/wav |
video | 表明是某种视频文件 | video/webn, video/ogg |
application | 表明是某种二进制数据 | application/octet-strean, application/pkcs12,application/vnd.mspowerpoint, application/xbtml.application/xml,application/pdf,application/json |
HTTP/2.0
HTTP/1.x报文有一些性能上的缺点:
- 消息头不像消息主体一样会被压缩。
- 两个报文之间的header通常非常相似,但它们仍然在连接中重复传输。
- 无法复用。当在同一个服务器打开几个连接时,TCP热连接比冷连接更加有效。HTTP/20引人了一个额外的步骤,它将HTTP/1x消息分成帧并嵌人到流(strean)中。