HTTP 报文格式是怎么分割的?
HTTP 协议的请求报文和响应报文的结构基本相同,由三大部分组成:
- 起始行(start line):描述请求或响应的基本信息;
- 头部字段集合(header):使用 key-value 形式更详细地说明报文;
- 实体(entity):实际传输的数据,它不一定是纯文本,可以是图片、视频等二进制数据。
HTTP 协议规定报文必须有 header,但可以没有 body,而且在 header 之后必须要有一个“空行”,也就是“CRLF”,十六进制的“0D0A”。
所以,一个完整的 HTTP 报文就像是下图的这个样子,注意在 header 和 body 之间有一个“空行”。
下面是一个详细的请求报文结构的例子:
他像不像是一个大头儿子?大大的 header 和 小小的 body,有时甚至没有 body
HTTP请求报文和响应报文?
请求报文
HTTP请求报文是客户端向服务器发送的数据格式,用于请求服务器执行特定操作或者提供特定资源。
HTTP 请求报文格式分为 请求行、请求头和请求体三个部分:
- 请求行是请求的基本信息,比如请求方法、资源路径、HTTP版本信息;
- 请求头使用 key-value 形式更详细的说明报文,比如 Host字段、Connection 字段、Content-Length 字段等;
- 请求体是实际传输的数据,比如文本数据、图片数据等,可以为空。
请求行和请求头是通过 \r\n 分割的,请求头和请求体之间是通过空白分割的,也就是两个连续的 \r\n。
请求头字段
请求头的字段较多,常使用的包含以下几个:
-
Host:请求的服务器的域名。
-
Accept:客户端能够处理的媒体类型。
-
Accept-Encoding:客户端能够解码的内容编码。
-
Authorization:用于认证的凭证信息,比如token数据。
-
Content-Length:请求体的长度。
-
Content-Type:请求体的媒体类型。
-
Cookie:存储在客户端的cookie数据。
-
If-None-Match:资源的ETag值,用于缓存控制。
-
Connection:管理连接的选项,如 keep-alive。
响应报文
HTTP响应报文是服务器向客户端返回的数据格式,用于传达服务器对客户端请求的处理结果以及相关的数据。
HTTP 响应报文格式分为 状态行、响应头和响应体三个部分:
- 状态行包括 HTTP 版本、一个三位数的响应码和相应的描述信息;例如
HTTP/1.1 200 OK
- 响应头也使用 key-value 形式,提供附加信息,比如 Content-Type 表明响应体的媒体类型、Content-Length 表明响应体的大小等;
- 响应体是服务器发送给客户端的实际数据,可以是文本、图片、视频等资源,也可能为空。
响应头字段
常见的响应头部字段包括:
-
Content-Type:指定响应主体的媒体类型。
-
Content-Length:指定响应主体的长度(字节数)。
-
Server:指定服务器的信息。
-
Expires: 响应的过期时间,之后内容被认为是过时的。
-
ETag: 响应体的实体标签,用于缓存和条件请求。
-
Last-Modified: 资源最后被修改的日期和时间。
-
Location:在重定向时指定新的资源位置。
-
Set-Cookie:在响应中设置Cookie。
-
Access-Control-Allow-Origin: 跨源资源共享(CORS)策略,指示哪些域可以访问资源。