前言
http状态码用来告诉客户端发生了什么事情,状态码位于响应的起始行中。通过三位数字代码对不同状态码进行分类。
整体范围 | 已定义范围 | 分类 |
---|---|---|
100~199 | 100~101 | 信息提示 |
200~299 | 200~206 | 成功 |
300~399 | 300~305 | 重定向 |
400~499 | 400~415 | 客户端错误 |
500~599 | 500~506 | 服务器错误 |
随着协议的发展,HTTP规范中会正式地定义更多的状态码。状态为客户端提供了一种理解事务处理结果的便捷方式。
100~199——信息性状态码
状态码 | 原因短语 | 含义 |
---|---|---|
100 | Continue | 收到了请求的初始部分,请客户端继续。发送了这个状态码之后,服务器在收到请求之后必须进行响应 |
101 | Switching Protocols | 服务器正在根据客户端的指定,将协议切换成 Update首部所列的协议 |
200~299——成功状态码
服务器有一组用来表示成功的状态码,分别对应于不同类型的请求。
状态码 | 原因短语 | 含义 |
---|---|---|
200 | OK | 请求没问题,实体的主体部分包含了所请求的资源 |
201 | Created | 用于创建服务器对象请求(PUT) |
202 | Accepted | 请求已被接受,但服务器还未对其执行任动作 |
203 | Non-Authoritative Information | 实体首部包含的信息不是来自于源端服务器,而是来自资源的一份副本 |
204 | No Content | 响应报文中没有实体的主体部分 |
205 | Reset Content | 告知浏览器清楚当前页面中的所有HTML表单元素 |
206 | Partial Content | 成功执行了一个部分或Range请求。 |
300~399——重定向状态码
如果资源已被移动,服务器可发送一个重定向状态码和一个可选的Location首部来告知客户端可以在哪找到被移动的资源。
状态码 | 原因短语 | 含义 |
---|---|---|
300 | Multiple Choices | 客户端请求一个实际指向多个资源的URL时使用 |
301 | Moved Permanently | 请求的URL被移除时使用,响应的Location首部中应该包含资源现在所处的URL |
302 | Found | 与301类似,Location首部给出的URL只是临时定为资源。以后的请求仍应使用老的URL |
303 | See Other | 告知客户端应该用另一个URL来获取资源 |
304 | Not Modified | 客户端可以通过所包含的请求首部,使其请求变成有条件的 |
305 | Use Proxy | 用来说明必须通过一个代理来访问资源,代理的位置由Location首部给出 |
306 | 未使用 | 当前未使用 |
307 | Temporary Redirect | 与301类似,Location首部给出的URL只是临时定为资源。以后的请求仍应使用老的URL |
302,303和307状态码之间存在一些交叉。这些状态码的用法有着细微的差别,大部分差别都源于HTTP/1.0和HTTP/1.1应用程序对这些状态码处理方式的不同。
400~499——客户端错误状态码
当客户端发送一些服务器无法处理的东西时,服务器会返回这一组状态码。很多客户端错误都是由浏览器来处理的,甚至不会打扰你。只有少量错误会穿过浏览器来到用户面前。
状态码 | 原因短语 | 含义 |
---|---|---|
400 | Bad Request | 用于告知客户端它发送了一个错误的请求 |
401 | Unauthorized | 与适当的首部一同返回,请求客户端在获取对资源的访问权之前,对自己进行认证 |
402 | Payment Required | 已被保留,暂未使用 |
403 | Forbidden | 用户说明请求被服务器拒绝了。这个状态码通常是在服务器不想说明拒绝原因的时候使用 |
404 | Not Found | 用户说明服务器无法找到所请求的URL |
405 | Method Not Allowed | 收到的请求中带有所请求的URL不支持的方法时,使用此状态码。应该在响应中包含Allow首部,以告知客户端可以使用的方法 |
406 | Not Acceptable | 客户端可以指定参数来说明它们愿意接收什么类型的实体。服务器没有与客户端可接受的URL相匹配的资源时,使用此代码 |
407 | Proxy Authentication Required | 与401状态码类似,但用于要求对资源进行认证的代理服务器 |
408 | Request Timeout | 如果客户端完成请求所花费的时间太长,服务器可以回送此状态码,并关闭连接 |
409 | Conflict | 用户说明请求可能在资源上引发的一些冲突。服务器担心请求会引发冲突时,可以发送此状态码 |
410 | Gone | 与404类似,知识服务器曾经拥有过此资源 |
411 | Length Required | 服务器要求在请求报文中包含Content-Length首部时使用 |
412 | Precondition Failed | 客户端发起了条件请求,且其中一个条件失败了的时候使用 |
413 | Request Entiy Too Large | 客户端发送的实体主体部分比服务器能够或者希望处理的要打时,使用此状态码 |
414 | Request URL Too Long | 客户端所发送的请求URL比服务器能够或者希望处理的要打时,使用此状态码 |
415 | Unsupported Media Type | 服务器无法理解或无法支持客户端所发实体的内容类型时,使用此状态码 |
416 | Requested Range Not Satisfiable | 请求报文所请求的是指定资源的某个范围,而此范围无效或无法满足时,使用此状态码 |
417 | Expectation Failed | 请求的Expect请求首部包含了一个期望,单服务器无法满足此期望,使用此状态码 |
500~599——服务器错误状态码
客户端发送了一条有效请求,服务求自身却出错了。可能是服务器的缺陷,或者是服务器上的子元素,比如某个网关资源出了错等。
状态码 | 原因短语 | 含义 |
---|---|---|
500 | Internal Server Error | 服务器遇到了一个妨碍它为请求提供服务的错误时,使用此状态码 |
501 | Not Implemented | 客户端发起的请求超过服务器的能力范围,使用此状态码 |
502 | Bad Gatway | 作为代理或网关使用的服务器从请求响应链的下一条链路上收到了一条伪响应时,使用此状态码 |
503 | Service Unavailable | 用来说明服务器现在无法为请求提供服务,但将来可以 |
504 | Gatway Timeout | 与状态码408类似,这里的响应来自一个网关或代理,它们在等待另一个服务器对其请求进行响应时超时了 |
505 | HTTP Version Not Supported | 服务器收到的请求使用了它无法或不愿支持的协议版本时,使用此状态码 |