HTTP状态码

简介: HTTP状态码

转载:http://www.cnblogs.com/-5012/p/5630598.html

一、1xx 消息

该类型的状态码代表请求已被接受,需要继续处理。

100 Continue

客户端应当继续发送请求,这个临时响应是用来通知客户端的部分请求已经被服务器接收,且仍未被拒绝。客户端应当继续发送请求的剩余部分。

如果请求已经完成,忽略这个响应。服务器必须在请求完成后向客户端发送一个最终响应。

101 Switching Protocols

服务器已经理解客户端的请求,并通过 Update 消息头通知客户端采用不同的协议来完成这个请求。只有在切换新的协议更有好处时,才采取类似措施。

102 Procsessing

扩展状态码,代表处理将被继续执行。

二、2xx 成功

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

200 OK

请求成功,请求所希望的响应头或数据体将随此响应返回。

201 Created

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

202 Accepted

服务器已接受请求,但尚未处理。正如它可能被拒绝一样,最终该请求可能会也可能不会被执行。

203 Non-Authoritative Information

服务器已成功处理了请求,但返回的实体头部元信息不是在原始服务器上有效的确定集合,而是来自本地或者第三方的拷贝。

204 No Content

服务器成功处理了请求,但不需要返回任何实体内容,并且希望返回更新了的元信息。该响应禁止包含任何消息体,始终以消息头后的第一个空行结束。

205 Reset Content

服务器成功处理了请求,且没有返回任何内容。与 204 不同之除在于,返回此状态码的响应要求请求者重置文档视图。该响应主要被用于接受用户输入后,

立即重置表单,以便用户能够开始另一次输入。同样被禁止包含任何消息体。

206 Partial Content

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

207 Multi-Status

扩展状态码,代表之后的消息体将是一个 XML 消息,并且可能依照之前子请求数量的不同,包含一系列独立的响应代码。

三、3xx 重定向

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

仅当后续请求所使用的方法是 GET 或 HEAD 时,用户浏览器才可以在没有用户介入的情况下自动提交所需要的后续请求。

客户端应当自动检测无限循环重定向,否则会导致双端不必要的资源消耗。HTTP/1.0 版规范建议,浏览器不应超过 5 次重定向。

300 Multiple Choices

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

除非这是一个 HEAD 请求,否则该响应应当包括一个资源特性及地址列表的实体,以便用户或浏览器从中选择最合适的重定向地址。

301 Moved Permanently

被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个 URI 之一。

302 Found

请求的资源现在临时从不同的 URI 响应请求。由于这样的重定向是临时的,客户端应当继续向原有地址发送以后的请求。

303 See other

对应当前请求的响应可以在另一个 URI 上被找到,而且客户端应当采用 GET 的方式访问那个资源。该请求禁止被缓存。

304 Not Modified

如果客户端发送了一个带条件的 GET 请求且该请求已被允许,而文档的内容自上次访问或根据请求的条件并没有改变,则服务器应当返回该状态码。

304 响应禁止包含消息体。

305 Use Proxy

被请求的资源必须通过指定的代理才能被访问。Location 域中将给出指定的代理所在 URI 的信息,接收者需要重复发送一个单独的请求,通过这个代理才能访问

相应的资源。只有原始服务器才能创建 305 响应。

306 Switch Proxy

最新版规范中,已经废弃。

307 Temporary Redirect

请求的资源现在临时从不同的 URI 响应请求。由于这样的重定向是临时的,客户端应当继续向原有地址发送以后的请求。只有在 Cache-Control 或 Expires 中进行

了指定的情况下,这个响应才是可缓存的。

四、4xx

该类型的状态码代表了客户端看起来可能发生了错误,妨碍了服务器的处理。

400 Bad Request

由于包含语法错误,当前请求无法被服务器理解。除非进行修改,否则客户端不应该重复提交这个请求。

401 Unauthorized

当前请求需要用户验证。

402 Payment Required

预留

403 Forbidden

服务器已经理解请求,但是拒绝执行。

404 Not Found

请求失败,请求所希望得到的资源未被在服务器上发现。

405 Method Not Allowed

请求的资源的内容特性无法满足请求头中的条件,因而无法生成响应实体。

407 Proxy Authentication Required

与 401 响应类似,只不过客户端必须在代理服务器进行身份验证。代理服务器必须返回一个 Proxy-Authenticate 用以身份询问。

408 Request Timeout

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

409 Conflict

由于和被请求的资源的当前状态之间存在冲突,请求无法完成。

410 Gone

被请求的资源在服务器上已经不再可用,而且没有任何已知的转发地址。

411 Length Required

服务器拒绝在没有定义 Content-Length 头的情况下接受请求。

412 Precondition Failed

服务器在验证请求的头字段中给出先决条件时,没能满足其中的一个或多个。

413 Request Entity Too Large

服务器拒绝处理当前请求,因为该请求提交的实体数据大小超过了服务器愿意或能够处理的范围。

414 Request-URI Too Long

请求的 URI 长度超过了服务器能够解释的长度,因此服务器拒绝对该请求提供服务。

415 Unsupported Media Type

对于当前请求的方法和所请求的资源,请求中提交的实体并不是服务器所支持的格式,因此请求被拒绝。

416 Request Range Not Satisfiable

如果请求中包含了 Range 请求头,并且 Range 中指定的任何数据范围都与当前资源的可用范围不重合,同时请求中又没有定义 If-Range 请求头,

那么服务器就应当返回 406 状态码。

417 Expectation Failed

在请求头 Expect 中指定的预期内容无法被服务器满足,或者这个服务器是一个代理服务器,它有明显的证据证明在当前路由的下一个节点上,Expect 的内容无法被满足。

418 I'm a teapot

不需要定义,是一个玩笑,为愚人节制定的。

421 There are too many connections from your internet address

从当前客户端所在的 IP 地址到服务器的连接数超过了服务器的许可最大范围。通常,这里的 IP 地址指的是从服务器看到的客户端地址。这里的客户端不一定是终端用户。

422 Unprocessable Entity

请求格式正确,但是由于含有语义错误,无法响应。

423 Locked

当前资源被锁定。

424 Failed Dependency

由于之前的某个请求发生的错误,导致当前请求失败。

425 Unordered Collection

没正式使用。

426 Upgraed Required

客户端应当切换到 TLS/1.0。

449 Retry With

由微软扩展,代表请求应当在执行完适当的操作后进行重试。

451 Unavailable For Legal Reasons

由 IETF 核准,代表访问因法律的要求被拒绝。

五、5xx 服务器错误

该类型的状态码代表了服务器在处理请求的过程中有错误或者异常状态发生,也有可能是服务器意识到以当前的软硬件资源无法完成对请求的处理。

500 Internal Server Error

服务器遇到了一个未曾预料的状况,导致了它无法完成对请求的处理。一般来讲,会出在服务器程序代码出错时出现。

501 Not Implemented

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

502 Bad Gateway

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

503 Service Unavailable

由于临时的服务器维护或过载,服务器当前无法处理请求。

504 Gateway Timeout

作为网关或者代理工作的服务器尝试执行请求时,未能及时从上游服务器或者辅助服务器收到响应。

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

505 HTTP Version Not Supported

服务器不支持,或者拒绝支持在中使用的 HTTP 版本。这暗示着服务器不能或不愿意与客户端相同的版本。

506 Variant Also Negotiates

由《透明内容协商协议》扩展,代表服务器存在内部配置错误。

507 Insufficient Storage

服务器无法存储完成请求所必须的内容。

509 Bandwidth Limit Exceeded

服务器达到带宽限制。这不是一个官方的状态吗,但仍被广泛使用。

510 Not Extended

获取资源所需要的策略并没有被满足。


相关文章
|
3月前
|
Shell
HTTP状态码解析:在Haskell中判断响应成功与否
HTTP状态码解析:在Haskell中判断响应成功与否
|
2月前
|
开发者
深入了解HTTP状态码
深入了解HTTP状态码
184 64
|
4月前
|
SQL 分布式计算 DataWorks
DataWorks操作报错合集之遇到报错:HTTP状态码400,该如何处理
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
2月前
|
缓存 网络协议 JavaScript
【HTTP】构造HTTP请求和状态码
【HTTP】构造HTTP请求和状态码
57 1
【HTTP】构造HTTP请求和状态码
|
2月前
|
缓存 应用服务中间件 nginx
你知道 HTTP 的状态码都有哪些吗?它们的含义又是什么呢?
你知道 HTTP 的状态码都有哪些吗?它们的含义又是什么呢?
67 9
|
2月前
|
缓存 前端开发 安全
前端开发者必备:HTTP状态码含义与用途解析,常见错误码产生原因及解决策略
前端开发者必备:HTTP状态码含义与用途解析,常见错误码产生原因及解决策略
188 0
|
3月前
|
开发者
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
HTTP状态码是由网页服务器返回的三位数字响应代码,用于表示请求的处理结果和状态
37 1
|
3月前
|
测试技术 API
8-20|https://gitlab.xx.com/api/v4/projects/4/trigger/pipeline Request failed 状态码400
8-20|https://gitlab.xx.com/api/v4/projects/4/trigger/pipeline Request failed 状态码400
|
3月前
|
API
探索研究Servlet HTTP 状态码
【9月更文挑战第24天】
39 0
|
4月前
|
缓存 Java Apache
常见的 HTTP 状态码分类及说明
这篇文章介绍了常见的HTTP状态码分类及其说明,包括1xx信息响应、2xx成功、3xx重定向、4xx客户端错误和5xx服务器错误,并提供了一个使用Apache HttpClient进行HTTP POST请求的Java代码示例。