安全测试 - HTTP 响应

HTTP 响应

在接收并解释请求消息后,服务器会使用 HTTP 响应消息 − 进行响应

  • 状态行

  • 零个或多个标头 (General|Response|Entity) 字段,后跟 CRLF

  • 空行(即 CRLF 前没有任何内容的行),表示标头字段的结尾

  • 可选的消息正文

以下部分解释了 HTTP 消息中使用的每个实体 −

消息状态行

状态行由协议版本、后跟数字状态代码及其相关文本短语组成。元素之间用空格 SP 字符分隔。

Status-Line = HTTP-Version SP Status-Code SP Reason-Phrase CRLF

让我们讨论一下 Status-Line 中提到的每个部分。

HTTP 版本

支持 HTTP 版本 1.1 的服务器返回以下版本信息 −

HTTP-Version = HTTP/1.1

状态码

Status-Code 元素是一个 3 位整数,其中 Status-Code 的第一位定义响应的类别,最后两位不具有任何分类作用。第一位有五个值 −

S.No. 值和说明
1

1xx:信息

这意味着请求已收到并继续处理。

2

2xx:成功

这意味着操作已成功接收、理解和接受。

3

3xx:重定向

这意味着必须采取进一步的行动才能完成请求。

4

4xx:客户端错误

这意味着请求包含错误的语法或无法满足

5

5xx:服务器错误

服务器未能满足看似有效的请求

HTTP 状态代码是可扩展的,HTTP 应用程序不需要了解所有已注册状态代码的含义。

响应标头字段

响应标头字段允许服务器传递有关响应的其他信息,这些信息无法放置在状态行中。这些标头字段提供有关服务器的信息以及对由 Request-URI 标识的资源的进一步访问。

  • Accept-Ranges
  • Age
  • ETag
  • Location
  • Proxy-Authenticate
  • Retry-After
  • Server
  • Vary
  • WWW-Authenticate

如果您希望编写自己的自定义 Web 客户端和服务器,可以引入自定义字段。

响应消息示例

现在让我们将所有内容放在一起,形成一个 HTTP 响应,用于请求从 tutorialspoint.com 上运行的 Web 服务器获取 hello.htm 页面

HTTP/1.1 200 OK
Date: Mon, 27 Jul 2009 12:28:53 GMT
Server: Apache/2.2.14 (Win32)
Last-Modified: Wed, 22 Jul 2009 19:15:56 GMT
Content-Length: 88
Content-Type: text/html
Connection: Closed

<html>
   <body>
      <h1>Hello, World!</h1>
   </body>
</html>

以下是 HTTP 响应消息的示例,显示了当 Web 服务器无法找到请求的页面时的错误情况 −

HTTP/1.1 404 Not Found
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Connection: Closed
Content-Type: text/html; charset = iso-8859-1
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
   <head>
      <title>404 Not Found</title>
   </head>

   <body>
      <h1>Not Found</h1>
      <p>The requested URL /t.html was not found on this server.</p>
   </body>
</html>

以下是 HTTP 响应消息的示例,显示了当 Web 服务器在给定的 HTTP 请求中遇到错误的 HTTP 版本时的错误情况 −

HTTP/1.1 400 Bad Request
Date: Sun, 18 Oct 2012 10:36:20 GMT
Server: Apache/2.2.14 (Win32)
Content-Length: 230
Content-Type: text/html; charset = iso-8859-1
Connection: Closed
   
<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN">
<html>
   <head>
      <title>400 Bad Request</title>
   </head>
   
   <body>
      <h1>Bad Request</h1>
      <p>Your browser sent a request that this server could not understand.<p>
      <p>The request line contained invalid characters following the protocol string.<p>
   </body>
</html>

http_protocol_basics.html