「理解HTTP」之常见的状态码

状态码的职责是当客户端向服务器端发送请求时,描述返回请求结果。借助状态码,用户能够知道服务器端是正常处理了请求,仍是出现了什么错误。react

RFC2616定义的状态码,由3位数字和缘由短信组成。
数字中的第一位指定了响应类别,后两位无分类。响应类别有如下5种:git

Type Reason-phrase Note
1XX Informational 信息性状态码,表示接受的请求正在处理
2XX Success 成功状态码,表示请求正常处理完毕
3XX Redirection 重定向状态码,表示须要客户端须要进行附加操做
4XX Client Error 客户端错误状态码,表示服务器没法处理请求
5XX Server Error 服务器错误状态码,表示服务器处理请求出错

RFC2616记录的HTTP状态码有37种,再加上「WebDAV」(RFC49185842)和「Additional HTTP Status Codes」(RFC6585),数量就达到60多种。
然并卵,这么多种HTTP状态码,其实经常使用的大概只有14种,本文就讲讲这14种状态码。浏览器

2XX Success

This class of status code indicates that the client's request was successfully received, understood, and accepted.服务器

2xx 响应结果表示从客户端发来的请求在服务器端被正常处理了。app

200 OK

请求被成功处理,服务器会根据不一样的请求方法返回结果:
GET:请求的对应资源会做为响应返回。
HEAD:请求的对应资源的响应头(entity-header)会做为响应返回,不包括响应体(message-body)。
POST:返回处理对应请求的结果。spa

204 No Content

该状态码表示服务器接收到的请求已经处理完毕,可是服务器不须要返回响应体.
好比,客户端是浏览器的话,发出的请求返回204响应,那么浏览器显示的页面不会发生更新。code

206 Partial Content

该状态码表示客户端进行了范围请求,而服务器成功执行了这部分的GET请求。
客户端发起的请求,必须在请求头中包含Range字段。服务端响应报文中,必须包含由Content-Range指定范围的实体内容(entity-bodies )orm

3XX Redirection

This class of status code indicates that further action needs to be taken by the user agent in order to fulfill the request.server

3XX 响应结果代表浏览器须要执行某些特殊的处理以完成请求。资源

301 Movied Permanently

永久性重定向。该状态码表示请求的资源已经被分配了新的URI,而且之后使用资源如今所指的URI。而且根据请求的方法有不一样的处理方式:
HEAD:必须在响应头部Location字段中指明新的永久性的URI。
GET:除了有Location字段之外,还须要在响应体中附上永久性URI的超连接文本。
POST:客户端在发送POST请求,受到301响应以后,不该该自动跳转URI,应当让用户确认跳转。

好比,若是一个URI已经在浏览器中被收藏为书签,这时应该按照Location首部字段提示的URI从新保存。
例如创建一个收藏的书签:

http://wan.bigertech.com

当访问这个书签的时候,请求会被重定向到

http://wan.meizu.com

而且对应的书签会被改变,指向http://wan.meizu.com
不信?Try yourself.

302 Found

临时性重定向。该状态码表示请求的资源已被分配了新的URI,但愿用户本次能使用新的URI访问。
和301 Moved Permanently 状态码类似,但302状态码表明的资源不是被永久移动,只是临时性质的。
若是,用户把一个URI收藏为书签,302响应是不会像301那样去更新书签。

303 See Other

该 状态码表示因为请求对应的资源存在另外一个URI,应使用GET方法定向获取请求的资源。303与302不一样之处在于,302是不会改变请求的方法,若是请 求方法是POST的话,重定向的请求也应该是POST。而对于303,使用POST请求的话,重定向的请求应该是GET请求。
可是有一点是须要注意的,许多HTTP/1.1版之前的浏览器不能正确理解303状态码,不少现存的浏览器讲302响应视为303响应,而且使用GET方式访问Location中规定的的URI,而无视原先请求的方法。
在RFC2616中有相关的这样一段原文:

Note: Many pre-HTTP/1.1 user agents do not understand the 303 status. When interoperability with such clients is a concern, the 302 status code may be used instead, since most user agents react to a 302 response as described here for 303.

304 Not Modified

该状态码表示客户端发送附带条件请求时,服务器端容许请求访问资源,但未知足条件的状况。304状态码返回时,不包含任何响应的主题部分。附带条件的请求指的是采用GET方法的请求头中包含:If-MatchIf-Modified-SinceIf-None-MatchIf-RangeIf-Unmodified-Since中任一首部。

307 Temporary Redirect

临时重定向。该状态码与302和303的有着相似的含义,不一样之处在于,307状态码并不会指定客户端要用什么样的请求方法请求重定向地址。(302指定使用原有请求方法,303指定使用GET方法)

4XX Client Error

The 4xx class of status code is intended for cases in which the client seems to have erred.

4XX 的响应结果代表客户端是发生错误的缘由所在

400 Bad Request

表示该请求报文中存在语法错误,致使服务器没法理解该请求。客户端须要修改请求的内容后再次发送请求。

401 Unauthorized

该状态码表示发送的请求须要有经过HTTP认证(Basic认证,Digest认证)的认证信息。返回含有401的响应,必须在头部包含WWW-Authenticate以指明服务器须要哪一种方式的认证。
当客户端再次请求该资源的时候,须要在请求头中的Authorization包含认证信息。
更多关于认证受权的信息关注RFC2617

403 Forbidden

该状态码代表对请求资源的访问被服务器拒绝了。服务器没有必要给出拒绝的详细理由,但若是想作说明的话,能够在实体的主体部分缘由进行描述,这样就能让用户看到了。
未得到文件系统的访问权限,访问权限出现某些问题,从未受权的发送源IP地址试图访问等状况均可能发生403响应。

404 Not Found

该状态码代表服务器上没法找到指定的资源。一般被用于服务器不想透露拒绝请求的缘由,或者没有其余的响应可提供。

5XX Server Error

Response status codes beginning with the digit "5" indicate cases in which the server is aware that it has erred or is incapable of performing the request.

5XX 的响应结果代表服务器自己发生错误,或者没有足够的能力来处理请求。

500 Internal Server Error

该状态码代表服务器端在执行请求时发生了错误。也有多是Web应用存在的BUG或某些临时的故障。

503 Service Unavailable

该状态码代表服务器暂时处于超负载或正在进行停机维护,如今没法处理请求。若是事先得知解除以上须要的时间,最好写入Retry-After首部字段再返回给客户端。

相关文章
相关标签/搜索