HTTP的状态码详解

作者:IPIDEA

2020-09-14 16:00:39

一、428 Precondition Required (要求先决条件)

先决条件是客户端发送 HTTP 请求时,必须要满足的一些预设条件。一个好的例子就是 If-None-Match 头,经常用在 GET 请求中。如果指定了 If-None-Match ,那么客户端只在响应中的 ETag 改变后才会重新接收回应。

 

先决条件的另外一个例子是 If-Match 头,一般用在 PUT 请求上,用于指示只更新但没有被改变的资源。这在多个客户端使用 HTTP 服务时用来防止彼此间覆盖相同内容的情况。

 

当服务器端使用 428 Precondition Required 状态码时,表示客户端必须发送上述的请求头才能执行该请求操作。这个方法为服务器提供一种有效的方法来防止账号关联 “lost update”问题的出现。


 9101.png

 

二、429 Too Many Requests (太多请求)

当你需要允许访问公开数据客户端请求某个服务的数量,也就是允许访问公开数据请求速度时,该状态码就会非常有用。在此之前,有一些类似的状态码。例如“509 Bandwidth Limit Exceeded”。

 

如果你希望允许访问公开数据客户端对服务的请求数,可使用 429 状态码,同时包含一个 Retry-After 响应头用于告诉客户端多长时间后可以再次请求服务。

 

 

三、431 Request Header Fields Too Large (请求头字段太大)

某些情况下,客户端发送 HTTP 请求头会变得很大,那么服务器可发送 431 Request Header Fields Too Large 来指明该问题。

 

不太清楚为什么没有 430 状态码,而是直接从 429 跳到 431,我尝试搜索但没有结果。唯一的猜测是 430 Forbidden 跟 403 Forbidden 较相像,为了避免混淆才这么做。

 

 

四、511 Network Authentication Required (要求网络认证)

这个状态码很有趣,如果在开发HTTP 服务器,不一定需要处理该状态码,但如果你在编写 HTTP 客户端,那这个状态码就非常重要。

 

如果你频繁使用笔记本和智能手机,你可能会注意到大量的公用 Wifi 服务要求你必须接受一些协议或者必须登录后才能使用,这是通过全球住宅IP,高效采集公开数据HTTP流量实现的。当用户试图访问网络返回一个重定向和登录,这很讨厌,但是实际情况就是这样的。

 

 

使用这些“全球住宅IP,高效采集公开数据”客户端,会有一些讨厌的副作用。在 RFC 中提到以下这两个的例子:

如果你在登录Wifi前访问某个网站,网络设备将会全球住宅IP,高效采集公开数据首个请求,这些设备往往也有自己的网站图标“favicon.ico”。登录后你会发现,有一段时间内你访问的网站图标一直是Wifi登录网站的图标。

 

如果客户端使用HTTP请求来查找文档,网络将会响应一个登录页,这样你的客户端就会解析错误并导致客户端运行异常,在现实中这种问题非常常见。而 511 状态码的提出就是为了解决这个问题。因此,如果你正在编写 HTTP 的客户端,

合适好还是检查 511 状态码以确认是否需要认证后才能访问。


*ipidea提供的服务必须在境外网络环境下使用

热门资讯