让我们逐行解释一个典型的HTTP请求报文:
GET /index.html HTTP/1.1
Host: www.example.com
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Firefox/91.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate, br
Connection: keep-alive
-
请求行:
GET /index.html HTTP/1.1
GET
是一个HTTP方法,表示请求的类型。GET方法通常用于请求服务器发送指定资源。/index.html
是请求的资源路径,即客户端想要获取的文件或资源的位置。HTTP/1.1
是HTTP协议的版本,这里指定为1.1。
-
请求头:
-
Host: www.example.com
指定了请求的主机名,这在虚拟主机环境中特别重要,因为一台服务器可能托管多个域名。 -
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Firefox/91.0
包含了发出请求的浏览器或客户端的详细信息,包括它的品牌、操作系统、版本等。 -
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
表明客户端能够处理的媒体类型,按照偏好顺序排列。q=0.9
和q=0.8
是质量因子,表示相对偏好。 -
Accept-Language: en-US,en;q=0.5
指定了客户端偏好的语言,这里是美式英语和英语,其中美式英语的偏好更高。 -
Accept-Encoding: gzip, deflate, br
列出了客户端能够理解的数据压缩编码,这可以帮助减少传输数据的大小。 -
Connection: keep-alive
表示客户端希望与服务器保持连接,而不是在每个请求/响应后关闭,这可以提高性能,因为它允许重复使用TCP连接。
-
让我们逐行解释一个典型的HTTP响应报文:
HTTP响应报文是服务器对客户端请求的答复。它包含了状态行、响应头、一个空行和响应体。下面是一个HTTP响应报文的例子,我们将逐行解释每一部分:
HTTP/1.1 200 OK
Date: Wed, 21 Oct 2020 05:00:00 GMT
Server: Apache/2.4.1 (Unix)
Content-Length: 1234
Content-Type: text/html; charset=UTF-8
Connection: close<html>
<head>
<title>Example Web Page</title>
</head>
<body>
<h1>Welcome to Example.com!</h1>
<p>This is a simple HTML document.</p>
</body>
</html>
-
状态行:
HTTP/1.1 200 OK
HTTP/1.1
表示服务器正在使用HTTP协议的1.1版本。200
是状态码,表示请求已成功处理。OK
是状态信息,伴随状态码提供额外的描述。
-
响应头:
-
Date: Wed, 21 Oct 2020 05:00:00 GMT
表示响应报文的创建日期和时间。 -
Server: Apache/2.4.1 (Unix)
显示了服务器软件的信息,包括服务器的类型和版本。 -
Content-Length: 1234
指定了响应体的大小,单位为字节。 -
Content-Type: text/html; charset=UTF-8
说明了响应体的媒体类型是HTML文档,字符编码是UTF-8。 -
Connection: close
指示服务器在发送完响应后关闭连接,不保持连接状态。
-
3. 响应体:
<html>
<head>
<title>Example Web Page</title>
</head>
<body>
<h1>Welcome to Example.com!</h1>
<p>This is a simple HTML document.</p>
</body>
</html>
响应体包含了服务器返回的实际数据,在这个例子中是HTML文档的内容。客户端(如浏览器)会根据Content-Type
解析和渲染这些数据。