众 所周知,每一个HTTP响应都会带有一个状态码,不过对于很多开发者来说,平时使用最多的几个状态码无外乎就是200、400、404、500等。那其他 众多状态码该应用在何种场景中,什么时候应该使用哪些状态码就成为一个值得我们深入思考的问题了。即便在Facebook这样的公司中,那些聪明的开发者 所构建的API也可能只返回200。
为此,Michael Kropat专门撰文分析了各个状态码的适用场景,以及我们为何要如此细致地区分不同状态码,同时还谈及了这么做的好处。
有什么是比返回一个HTTP状态码还要简单的事情呢?页面渲染了么?如果渲染,那就返回200呗。页面不存在?那就是404。需要将用户重定向到另外一个页面?那就使用302,也许301也行。
一切都是如此简单,不过当有人跟你说,你并没有以REST的方式做事情,你可能就要警醒了。新资源是否返回了RFC兼容、Roy-Fielding建议的状态码?只会是200么?也许是204 No Content、202 Accepted,抑或是201 Created?
问题在于官方HTTP/1.1指南(RFC)最初是在1997年发布的。那时的我们还在使用Netscape Navigator、33.6kbps的调试解调器网上冲浪呢。这就好比是在现代商业战略中使用孙子兵法一样。这些宝贵的建议并不会随着时间的流逝而发生变化。不过,我们需要真正理解他们。
如果有可视化的决策树就好了,它可以帮助你快速识别与你的情况相吻合的状态码,这样就能忽略掉那些不相关的了。请看下图。
上图看起来是显而易见的,不过我发现很多人都会陷入其中,并且提出诸如“这种情况应该使用503 Service Unavailable还是404 Not Found呢”?停。如果你在完全不同的响应类别中思考具体的状态码,那就表明你的做法是完全错误的。再来看看上面这张图。
在继续之前我提出几点:
-
你不必非得听我的,请直接查看RFC 7231与httpstatuses.com
-
我所面向的读者是那些创建网站或是使用REST API的开发者
-
我将响应码大致划分为3大类
最后再提一点:我其实并没有什么资格就这个主题发表自己的看法,我只不过阅读过一些RFC并开发过一些APIs而已。如果觉得我说的不对,或是没有使用你倾向于使用的状态码,那么请在文末的评论中指出来,大家一起讨论。
2XX/3XX
4XX
5XX
为何说状态码很重要
虽说Facebook中很多聪明的开发者在构建APIs时只返回200,但我想说的是,状态码确实是非常重要的。现有的状态码对于现代网站/API来说有些太宽泛了。如果响应要以应用特定的格式来包含一些细节信息,比如说哪些字段验证失败了,原因是什么,这样可以让客户端以更加有意义的方式来处理响应。既然如此,那为何不多花点时间来研究一下那些“不太常用”的HTTP状态码呢?
在谈及为何说使用具体的状态码是非常重要的时候,人们很爱提到的一个原因就是HTTP是个分层系统,客户端与服务器之间可能存在着代理、缓存或是其他HTTP库,如果响应码有意义,那会让这一切都工作地更好。不过,我觉得这个解释站不住脚,比如说未来大家都使用上了HTTPS,我们也禁用掉了所有代理与缓存结点,你能说这时状态码就没用了么?
这里,我想谈谈我认为状态码依然很重要的3点原因:
1. 客户端可以针对不同的状态码采取不同的行为(或是可以轻松扩展以应对):
-
301 Moved Permanently与302 Found对于Google与其他搜索引擎来说还有SEO的隐喻
-
301 Moved Permanently有缓存的含义,而429 Too Many Requests则没有缓存的含义,诸如此类
-
客户端库可以通过一段时间的延迟后重试请求来处理429 Too Many Requests
-
客户端库可以采取类似的方式处理503 Service Unavilable
2. 很多状态码所表示的情况可以通过特殊的响应进行处理。
-
返回404而非405 Method Not Allowed的APIs有时会让我抓狂,“我是输错了URL还是使用了错误的HTTP方法呢”?
-
正确区分502 Bad Gateway与500 Internal Server Error会让你省下不少的调试时间。
3. 不管信不信,目前很多流行的APIs建立了一些约定,比如说返回201 Created、429 Too Many Requests,或是503 Service Unavilable。如果遵循这些约定,那么用户在使用你的网站/API时就会更轻松,遇到问题时也更容易解决
原文:http://mp.weixin.qq.com/s?__biz=MjM5MDE0Mjc4MA==&mid=401821044&idx=1&sn=af24755036261ac99dcde8f949183025&scene=23&srcid=1218N1N9RponeSlN1Z6fBSoh#rd
相关推荐
### HTTP状态码详解 HTTP状态码是Web服务器与客户端(如浏览器)通信的重要组成部分,用于指示请求的结果。...每个状态码都有其特定的含义和应用场景,正确理解和使用HTTP状态码对于开发健壮的网络应用至关重要。
### HTTP状态码详解 HTTP(Hypertext Transfer Protocol)是互联网上应用最为广泛的一种网络协议。它定义了一系列的请求和响应消息格式,并规定了客户端和服务端之间如何进行数据传输。HTTP状态码是HTTP协议中非常...
HTTP状态码用于告知客户端请求的状态。这些状态码分为五类:1xx(信息性响应)、2xx(成功响应)、3xx(重定向响应)、4xx(客户端错误)以及5xx(服务器错误)。接下来,我们将逐一探讨这些状态码的具体含义及其在...
#### 一、信息性状态码(1xx) ...综上所述,HTTP状态码对于理解客户端与服务器之间的交互至关重要。通过正确识别和解释这些状态码,开发者和网络管理员可以有效地诊断问题、优化应用程序性能并提升用户体验。
HTTP状态码是服务器向客户端返回的一种反馈,表示请求处理的结果。这些状态码通常是一个三位数字,分为五个主要类别,每个类别代表不同的含义。 1xx(Informational 1xx)状态码表示临时响应,即服务器正在处理请求...
### HTTP状态码详解 HTTP状态码是Web服务器与客户端(如浏览器或爬虫程序)通信过程中,用于描述请求结果的一种标准化编码方式。当客户端向服务器发送请求时,服务器会返回一个HTTP状态码来告知客户端其请求的状态...
HTTP 返回状态码是 Hypertext Transfer Protocol(超文本传输协议)中的一种机制,用于表示服务器对客户端请求的响应结果。状态码是三位数字,第一个数字定义了响应的类别,后两个数字定义了响应的详细信息。 以下...
此外,正确使用HTTP状态码对于提升用户体验和网站SEO表现也至关重要。例如,合理的使用301状态码可以保持链接权重,避免因资源位置变动而导致的权重流失;而利用302状态码则可以在不影响搜索排名的情况下临时重定向...
在Web开发中,HTTP状态码是服务器响应客户端请求时所返回的一个特定的代码,它反映了请求的执行结果,从而让客户端了解请求是否成功执行...在实际工作中,还应根据具体的API设计指南和最佳实践来选择合适的HTTP状态码。
HTTP状态码是网络通信中一个至关重要的组成部分,用于在客户端和服务器之间传递状态信息,帮助双方理解和处理HTTP请求的结果。以下是对HTTP状态码的详细解析,涵盖了从1xx到5xx的主要状态码。 ### 一、1xx(临时...
### HTTP状态码详解 HTTP(超文本传输协议)是互联网上应用最为广泛的一种网络协议,它定义了客户端(如浏览器)与服务器之间的通信规则。在客户端向服务器发送请求后,服务器会返回一个状态码,用来指示请求是否...
HTTP 状态码详解 HTTP 状态码是服务端返回给浏览器客户端的 3 位数字代码,相当于浏览器和服务器之间的对话信息。这些状态码能够快速地诊断错误,减少网站的停机时间等等。在一般的响应头中状态行是由 3 位数字的...
HTTP服务器状态码是HTTP协议中用来表示客户端请求与服务器交互情况的一种编码方式,它由三位数字组成,分为五类:1xx(信息性...理解HTTP状态码能够帮助开发者和测试人员定位和解决问题,确保系统的稳定性和正确性。
### HTTP状态码及它们的用途 HTTP状态码是Web服务器响应客户端请求时返回的一个标准代码,用以指示请求是否成功、失败或者需要采取其他行动的原因。根据不同的数值范围,这些状态码可以分为以下几类: #### 100-...
### HTTP状态码详解 HTTP状态码是Web服务器与客户端(如浏览器)进行通信时返回的一种标准响应码,用于表示请求的结果。状态码分为五个类别,分别以1xx、2xx、3xx、4xx和5xx开头,表示信息性响应、成功响应、重定向...
HTTP状态码是网络通信中非常重要的元素,它们用于表示服务器对客户端请求的响应状态。HTTP状态码由三位数字组成,并附带一个简短的原因短语,帮助开发者理解服务器的响应情况。以下是关于服务器返回的十四种常见HTTP...
根据提供的文件信息,本文将详细介绍HTTP错误的种类及原因,重点讲解状态码及其对应的含义。 HTTP(HyperText Transfer Protocol,超文本传输协议)是互联网上应用最为广泛的网络协议之一。当网络通信出现问题时,...
理解这些状态码对于诊断网络问题、优化网站性能以及确保搜索引擎能够正确抓取网站内容至关重要。 1xx(临时响应): 100(继续):当客户端发送大请求时,服务器可能会先返回100状态码,告知客户端继续发送剩余的...