【前端 · 面试 】HTTP 总结(四)—— HTTP 状态码

这是我参与8月更文挑战的第4天,活动详情查看:8月更文挑战前端

最近我在作前端面试题总结系列,感兴趣的朋友能够添加关注,欢迎指正、交流。git

争取每一个知识点可以多总结一些,至少要作到在面试时,针对每一个知识点均可以侃起来,不至于哑火。面试

前言

经过前面的总结,咱们都知道,当客户端经过 HTTP 向服务端发送了一个请求以后,老是指望服务端可以进行响应。而在服务端的响应结果中,信息头会包含一个叫 Status Code 的属性,其值为一个三位数的数字,咱们将这个数字称为 HTTP 状态码编程

HTTP 状态码 是 HTTP 协议的重要组成部分,它用来表示服务端对当前请求的响应状态浏览器

概念

HTTP 状态码(英语:HTTP Status Code)是用来表示网页服务器 HTTP 协议响应状态的 3 位数字代码。缓存

它由 RFC 2616 规范定义的,并获得 RFC 251八、RFC 281七、RFC 229五、RFC 2774 与 RFC 4918 等规范扩展。服务器

全部状态码的第一个数字表明了响应的五种状态之一。所示的消息短语是典型的,可是能够提供任何可读取的替代方案。markdown

分类

HTTP 状态码分为五类,以下图所示:网络

HTTP 状态码分类

1xx 消息

这一类型的状态码,表明请求已被接受,须要继续处理。有如下特性:异步

  • 这类响应是临时响应,只包含状态行和某些可选的响应头信息,并以空行结束。
  • 因为HTTP/1.0协议中没有定义任何1xx状态码,因此除非在某些试验条件下,服务器禁止向此类客户端发送1xx响应。
  • 这些状态码表明的响应都是信息性的,标示客户应该等待服务器采起进一步行动。

100 Continue

服务器已经接收到请求头,而且客户端应继续发送请求主体(在须要发送身体的请求的状况下:例如,POST请求),或者若是请求已经完成,忽略这个响应。

服务器必须在请求完成后向客户端发送一个最终响应。

要使服务器检查请求的头部,客户端必须在其初始请求中发送 Expect: 100-continue 做为头部,并在发送正文以前接收100 Continue状态代码。

101 Switching Protocols

服务器已经理解了客户端的请求,并将经过Upgrade消息头通知客户端采用不一样的协议来完成这个请求。在发送完这个响应最后的空行后,服务器将会切换到在Upgrade消息头中定义的那些协议。

只有在切换新的协议更有好处的时候才应该采起相似措施。例如,切换到新的HTTP版本(如HTTP/2)比旧版本更有优点,或者切换到一个实时且同步的协议(如WebSocket)以传送利用此类特性的资源。

102 Processing

WebDAV请求可能包含许多涉及文件操做的子请求,须要很长时间才能完成请求。该代码表示服务器已经收到并正在处理请求,但无响应可用。这样能够防止客户端超时,并假设请求丢失。

103 Early Hints

用来在最终的HTTP消息以前返回一些响应头。

2xx 成功

这一类型的状态码,表明请求已成功被服务器接收、理解、并接受。

200 OK

请求已成功,请求所但愿的响应头或数据体将随此响应返回。出现此状态码是表示正常状态。

201 Created

请求已经被实现,并且有一个新的资源已经依据请求的须要而创建,且其 URI 已经随Location 头信息返回。

假如须要的资源没法及时创建的话,应当返回 '202 Accepted'。

202 Accepted

服务器已接受请求,但还没有处理。正如它可能被拒绝同样,最终该请求可能会也可能不会被执行。在异步操做的场合下,没有比发送这个状态码更方便的作法了。

返回202状态码的响应的目的是容许服务器接受其余过程的请求(例如某个天天只执行一次的基于批处理的操做),而没必要让客户端一直保持与服务器的链接直到批处理操做所有完成。

接受请求处理并返回202状态码的响应,应当在返回的实体中包含一些指示处理当前状态的信息,以及指向处理状态监视器或状态预测的指针,以便用户可以估计操做是否已经完成。

203 Non-Authoritative Information

服务器已成功处理了请求,但返回的实体头部元信息不是在原始服务器上有效的肯定集合,而是来自本地或者第三方的拷贝。当前的信息多是原始版本的子集或者超集。例如,包含资源的元数据可能致使原始服务器知道元信息的超集。使用此状态码不是必须的,并且只有在响应不使用此状态码便会返回200 OK的状况下才是合适的。

204 No Content

服务器成功处理了请求,但不须要返回任何实体内容,而且但愿返回更新了的元信息。响应可能经过实体头部的形式,返回新的或更新后的元信息。若是存在这些头部信息,则应当与所请求的变量相呼应。

若是客户端是浏览器的话,那么用户浏览器应保留发送了该请求的页面,而不产生任何文档视图上的变化,即便按照规范新的或更新后的元信息应当被应用到用户浏览器活动视图中的文档。

因为204响应被禁止包含任何消息体,所以它始终以消息头后的第一个空行结尾。

205 Reset Content

服务器成功处理了请求,且没有返回任何内容。

可是与204响应不一样,返回此状态码的响应要求请求者重置文档视图。该响应主要是被用于接受用户输入后,当即重置表单,以便用户可以轻松地开始另外一次输入。

与204响应同样,该响应也被禁止包含任何消息体,且以消息头后的第一个空行结束。

206 Partial Content

服务器已经成功处理了部分 GET 请求。相似于 FlashGet 或者迅雷这类的 HTTP下载工具都是使用此类响应实现断点续传或者将一个大文档分解为多个下载段同时下载。

该请求必须包含 Range 头信息来指示客户端但愿获得的内容范围,而且可能包含 If-Range 来做为请求条件。

响应必须包含以下的头部域:

  • Content-Range 用以指示本次响应中返回的内容的范围;若是是 Content-Type 为 multipart/byteranges 的多段下载,则每一 multipart 段中都应包含 Content-Range 域用以指示本段的内容范围。假如响应中包含 Content-Length,那么它的数值必须匹配它返回的内容范围的真实字节数。

  • Date

  • ETag 和/或 Content-Location,假如一样的请求本应该返回200响应。

  • Expires, Cache-Control,和/或 Vary,假如其值可能与以前相同变量的其余响应对应的值不一样的话。

假如本响应请求使用了 If-Range 强缓存验证,那么本次响应不该该包含其余实体头;假如本响应的请求使用了 If-Range 弱缓存验证,那么本次响应禁止包含其余实体头;这避免了缓存的实体内容和更新了的实体头信息之间的不一致。不然,本响应就应当包含全部本应该返回200响应中应当返回的全部实体头部域。

假如 ETag 或 Last-Modified 头部不能精确匹配的话,则客户端缓存应禁止将206响应返回的内容与以前任何缓存过的内容组合在一块儿。

207 Multi-Status

由WebDAV(RFC 2518)扩展的状态码,表明以后的消息体将是一个XML消息,而且可能依照以前子请求数量的不一样,包含一系列独立的响应代码。

208 Already Reported

DAV绑定的成员已经在(多状态)响应以前的部分被列举,且未被再次包含。

226 IM Used

服务器已经知足了对资源的请求,对实体请求的一个或多个实体操做的结果表示。

3xx 重定向

这类状态码表明须要客户端采起进一步的操做才能完成请求。一般,这些状态码用来重定向,后续的请求地址(重定向目标)在本次响应的 Location 域中指明。

当且仅当后续的请求所使用的方法是 GET 或者 HEAD 时,用户浏览器才能够在没有用户介入的状况下自动提交所须要的后续请求。

客户端应当自动监测无限循环重定向(例如:A->A,或者A->B->C->A),由于这会致使服务器和客户端大量没必要要的资源消耗。

按照 HTTP/1.0 版规范的建议,浏览器不该自动访问超过5次的重定向。

300 Multiple Choices

被请求的资源有一系列可供选择的回馈信息,每一个都有本身特定的地址和浏览器驱动的商议信息。用户或浏览器可以自行选择一个首选的地址进行重定向。

除非这是一个 HEAD 请求,不然该响应应当包括一个资源特性及地址的列表的实体,以便用户或浏览器从中选择最合适的重定向地址。这个实体的格式由 Content-Type 定义的格式所决定。浏览器可能根据响应的格式以及浏览器自身能力,自动做出最合适的选择。固然,RFC 2616规范并无规定这样的自动选择该如何进行。

若是服务器自己已经有了首选的回馈选择,那么在 Location 中应当指明这个回馈的 URI;浏览器可能会将这个 Location 值做为自动重定向的地址。此外,除非额外指定,不然这个响应也是可缓存的。

304 Not Modified

表示资源在由请求头中的If-Modified-Since或If-None-Match参数指定的这一版本以后,不曾被修改。在这种状况下,因为客户端仍然具备之前下载的副本,所以不须要从新传输资源。

306 Switch Proxy

在最新版的规范中,306状态码已经再也不被使用。最初是指“后续请求应使用指定的代理”。

4xx 客户端错误

这类的状态码表明了客户端看起来可能发生了错误,妨碍了服务器的处理。除非响应的是一个 HEAD 请求,不然服务器就应该返回一个解释当前错误情况的实体,以及这是临时的仍是永久性的情况。这些状态码适用于任何请求方法。浏览器应当向用户显示任何包含在此类错误响应中的实体内容。

若是错误发生时客户端正在传送数据,那么使用TCP的服务器实现应当仔细确保在关闭客户端与服务器之间的链接以前,客户端已经收到了包含错误信息的数据包。若是客户端在收到错误信息后继续向服务器发送数据,服务器的TCP栈将向客户端发送一个重置数据包,以清除该客户端全部还未识别的输入缓冲,以避免这些数据被服务器上的应用程序读取并干扰后者。

400 Bad Request

有两种可能:

  • 语义有误,当前请求没法被服务器理解。除非进行修改,不然客户端不该该重复提交这个请求。
  • 请求参数有误。

401 Unauthorized

当前请求须要用户验证。该响应必须包含一个适用于被请求资源的 WWW-Authenticate 信息头用以询问用户信息。客户端能够重复提交一个包含恰当的 Authorization 头信息的请求。若是当前请求已经包含了 Authorization 证书,那么401响应表明着服务器验证已经拒绝了那些证书。若是401响应包含了与前一个响应相同的身份验证询问,且浏览器已经至少尝试了一次验证,那么浏览器应当向用户展现响应中包含的实体信息,由于这个实体信息中可能包含了相关诊断信息。

403 Forbidden

服务器已经理解请求,可是拒绝执行它。与401响应不一样的是,身份验证并不能提供任何帮助,并且这个请求也不该该被重复提交。若是这不是一个 HEAD 请求,并且服务器但愿可以讲清楚为什么请求不能被执行,那么就应该在实体内描述拒绝的缘由。固然服务器也能够返回一个404响应,假如它不但愿让客户端得到任何信息。

404 Not Found

请求失败,请求所但愿获得的资源未被在服务器上发现。没有信息可以告诉用户这个情况究竟是暂时的仍是永久的。假如服务器知道状况的话,应当使用410状态码来告知旧资源由于某些内部的配置机制问题,已经永久的不可用,并且没有任何能够跳转的地址。404这个状态码被普遍应用于当服务器不想揭示到底为什么请求被拒绝或者没有其余适合的响应可用的状况下。出现这个错误的最有可能的缘由是服务器端没有这个页面。

405 Method Not Allowed

请求行中指定的请求方法不能被用于请求相应的资源。该响应必须返回一个Allow 头信息用以表示出当前资源可以接受的请求方法的列表。

鉴于 PUT,DELETE 方法会对服务器上的资源进行写操做,于是绝大部分的网页服务器都不支持或者在默认配置下不容许上述请求方法,对于此类请求均会返回405错误。

406 Not Acceptable

请求的资源的内容特性没法知足请求头中的条件,于是没法生成响应实体。

除非这是一个 HEAD 请求,不然该响应就应当返回一个包含可让用户或者浏览器从中选择最合适的实体特性以及地址列表的实体。实体的格式由 Content-Type 头中定义的媒体类型决定。浏览器能够根据格式及自身能力自行做出最佳选择。可是,规范中并无定义任何做出此类自动选择的标准。

408 Request Timeout

请求超时。客户端没有在服务器预备等待的时间内完成一个请求的发送。客户端能够随时再次提交这一请求而无需进行任何更改。

5xx 服务端错误

这类状态码表明了服务器在处理请求的过程当中有错误或者异常状态发生,也有多是服务器意识到以当前的软硬件资源没法完成对请求的处理。除非这是一个HEAD 请求,不然服务器应当包含一个解释当前错误状态以及这个情况是临时的仍是永久的解释信息实体。浏览器应当向用户展现任何在当前响应中被包含的实体。

这些状态码适用于任何响应方法。

500 Internal Server Error

服务器遇到了一个不曾预料的情况,致使了它没法完成对请求的处理。通常来讲,这个问题都会在服务器端的源代码出现错误时出现。

501 Not Implemented

服务器不支持当前请求所须要的某个功能。当服务器没法识别请求的方法,而且没法支持其对任何资源的请求。

502 Bad Gateway

做为网关或者代理工做的服务器尝试执行请求时,从上游服务器接收到无效的响应。

503 Service Unavailable

因为临时的服务器维护或者过载,服务器当前没法处理请求。这个情况是临时的,而且将在一段时间之后恢复。若是可以预计延迟时间,那么响应中能够包含一个 Retry-After 头用以标明这个延迟时间。若是没有给出这个 Retry-After 信息,那么客户端应当以处理500响应的方式处理它。

注意:503状态码的存在并不意味着服务器在过载的时候必须使用它。某些服务器只不过是但愿拒绝客户端的链接。

504 Gateway Timeout

做为网关或者代理工做的服务器尝试执行请求时,未能及时从上游服务器(URI标识出的服务器,例如HTTP、FTP、LDAP)或者辅助服务器(例如DNS)收到响应。

注意:某些代理服务器在DNS查询超时时会返回400或者500错误

505 HTTP Version Not Supported

服务器不支持,或者拒绝支持在请求中使用的 HTTP 版本。这暗示着服务器不能或不肯使用与客户端相同的版本。响应中应当包含一个描述了为什么版本不被支持以及服务器支持哪些协议的实体。

507 Insufficient Storage

服务器没法存储完成请求所必须的内容。这个情况被认为是临时的。

511 Network Authentication Required

客户端须要进行身份验证才能得到网络访问权限,旨在限制用户群访问特定网络。

总结

经过 HTTP 状态码,咱们能够判断当前服务端的状态。

状态码基本分为五类,每一类中又分为多个不一样小类,对应的内容较多,咱们只须要知道其中一些常见的状态码含义便可。

~

~ 本文完,感谢阅读!

~

~

学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!

你们好,我是〖编程三昧〗的做者 隐逸王,个人公众号是『编程三昧』,欢迎关注,但愿你们多多指教!

你来,怀揣指望,我有墨香相迎! 你归,不管得失,惟以余韵相赠!

知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!

相关文章
相关标签/搜索