新闻资讯

News Information

首页 > 新闻信息 > HTTP服务器状态码解析

HTTP服务器状态码解析

发布: 来源:又名江油站长网 日期:2019年09月24日 阅读:0

在做接口测试、性能测试的时候,会产生比较多的HTTP错误查看其错误,有超时的,链接不到图片的,连接不到服务器等。所以这块知识总结下。

HTTP服务器状态代码定义(Status Code Definitions)

1.1 消息1xx(Informational 1xx)

该类状态代码用于表示临时回应。临时回应由状态行(Status-Line)及可选标题组成, 由空行终止。HTTP/1.0中没有定义任何1xx的状态代码,所以它们不是对HTTP/1.0请求的 合法回应。实际上,它们主要用于实验用途,这已经超出本文档的范围。

1.2 成功2xx(Successful 2xx)

表示客户端请求被成功接收、理解、接受。

200 OK

请求成功。回应的信息依赖于请求所使用的方法,如下:

GET 要请求的资源已经放在回应的实体中了。

HEAD 没有实体主体,回应中只包括标题信息。

POST 实体(描述或包含操作的结果)。

201 Created

请求完成,结果是创建了新资源。新创建资源的URI可在回应的实体中得到。原始服务器应在发出该状态代码前创建该资源。如果该操作不能立即完成,服务器必须在该资源可用时在回应主体中给出提示,否则,服务器端应回应202(可被接受)。

在本文定义的方法,只有POST可以创建资源。

202 Accepted

请求被接受,但处理尚未完成。请求可能不一定会最终完成,有可能被处理过程随时中断,在这种情况下,没有办法在异步操作中重新发送状态代码。

202回应是没有义务的,这样做的目的是允许服务器不必等到用户代理和服务器间的连接结束,就可以响应其它过程的请求(象每天运行一次的,基于批处理的过程)。

在某些回应中返回的实体中包括当前请求的状态指示、状态监视器指针或用户对请求能否实现的评估信息。

204 No Content

服务器端已经实现了请求,但是没有返回新的信息。如果客户是用户代理,则勿需为此更新自身的文档视图。该回应主要是为了在不影响用户代理激活文档视图的前提下,进行script语句的输入及其它操作。该回应还可能包括新的、以实体标题形式表示的元信息,它可被当前用户代理激活视图中的文档所使用。

1.3 重定向(Redirection 3xx)

该类状态码表示用户代理要想完成请求,还需要发出进一步的操作。这些操作只有当后跟的请求是GET或HEAD时,才可由用户代理来实现,而不用与用户进行交互。用户代理永远也不要对请求进行5次以上的重定向操作,这样可能导致无限循环。

300 Multiple Choices

该状态码不被HTTP/1.0的应用程序直接使用,只是做为3xx类型回应的缺省解释。存在多个可用的被请求资源。

除非是HEAD请求,否则回应的实体中必须包括这些资源的字符列表及位置信息,由用户或用户代理来决定哪个是最适合的。

如果服务器有首选,它应将对应的URL信息存放在位置域(Location field)处,用户代理会根据此域的值来实现自动的重定向。

301 Moved Permanently

请求到的资源都会分配一个永久的URL,这样就可以在将来通过该URL来访问此资源。有编辑链接功能的客户端会尽可能地根据服务器端传回的新链接而自动更新请求URI。 新的URL必须由回应中的位置域指定。除非是HEAD请求,否则回应的实体主体 (Entity-Body)必须包括对新URL超链接的简要描述。

如果用POST方法发出请求,而接收到301回应状态码。在这种情况下,除非用户确认,否则用户代理不必自动重定向请求,因为这将导致改变已发出请求的环境。

注意:当在接收到301状态码后而自动重定向POST请求时,一些现存的用户代理会错误地将其改为GET请求。

302 Moved Temporarily

请求到的资源在一个不同的URL处临时保存。因为重定向有时会被更改,客户端应继续用请求URI来发出以后的请求。新的URL必须由回应中的位置域指定。除非是HEAD请求,否则回应的实体主体 (Entity-Body)必须包括对新URL超链接的简要描述。

如果用POST方法发出请求,而接收到302回应状态码。在这种情况下,除非用户确认,否则用户代理不必自动重定向请求,因为这将导致改变已发出请求的环境。

注意:当在接收到302状态码后而自动重定向POST请求时,一些现存的用户代理会错误地将其改为GET请求。

304 Not Modified

如果客户端成功执行了条件GET请求,而对应文件自If-Modified-Since域所指定的日期以来就没有更新过,服务器应当回应此状态码,而不是将实体主体发送给客户端。回应标题域中只应包括一些相关信息,比如缓存管理器、与实体最近更新(entity's Last-Modified)日期无关的修改。相关标题域的例子有:日期、服务器、过期时间。每当304回应中给出的域值发生变化,缓存都应当对缓存的实体进行更新。

1.4 客户端错误(Client Error )4xx

4xx类的状态码表示客户端发生错误。如果客户端在收到4xx代码时请求还没有完成,它应当立即终止向服务器发送数据。除了回应HEAD请求外,不论错误是临时的还是永久的,服务器端都必须在回应的实体中包含错误状态的解释。这些状态码适用于任何请求方法。

注意:如果客户端正在发送数据,服务器端的TCP实现应当小心,以确保客户端在关闭输入连接之前收到回应包。如果客户端在关闭后仍旧向服务器发送数据,服务器会给客户 端发送一个复位包,清空客户端尚未处理的输入缓冲区,以终止HTTP应用程序的读取、解释活动。

400 非法请求(Bad Request)

如果请求的语法不对,服务器将无法理解。客户端在对该请求做出更改之前,不应再次向服务器重复发送该请求。

401 未授权(Unauthorized)

请求需要用户授权。回应中的WWW-Authenticate标题域(10.16节)应提示用户以授权方式请求资源。客户端应使用合适的授权标题域(10.2节)来重复该请求。如果请求中已经包括了授权信任信息,那回应的401表示此授权被拒绝。如果用户代理在多次尝试之后,回应一样还是返回401状态代码,用户应当察看一下回应的实体,因为在实体中会包括一些相关的动态信息。HTTP访问授权会在11节中解释。

403 禁止(Forbidden)

服务器理解请求,但是拒绝实现该请求。授权对此没有帮助,客户端应当停止重复发送此请求。如果不是用HEAD请求方法,而且服务器端愿意公布请求未被实现原因的前提下,服务器会将拒绝原因写在回应实体中。该状态码一般用于服务器端不想公布请求被拒绝的细节或没有其它的回应可用。

404 没有找到(Not Found)

服务器没有找到与请求URI相符的资源。404状态码并不指明状况是临时性的还是永久性的。如果服务器不希望为客户端提供这方面的信息,还回应403(禁止)状态码。

1.5 服务器错误(Server Error )5xx

回应代码以‘5’开头的状态码表示服务器端发现自己出现错误,不能继续执行请求。如果客户端在收到5xx状态码时,请求尚未完成,它应当立即停止向服务器发送数据。除了回应HEAD请求外,服务器应当在其回应实体中包括对错误情况的解释、并指明是临时性的还永久性的。

这类回应代码没有标题域,可适用于任何请求方法。

500 服务器内部错误(Internal Server Error)

服务器碰到了意外情况,使其无法继续回应请求。

501 未实现(Not Implemented)

服务器无法提供对请求中所要求功能的支持。如果服务器无法识别请求方法就会回应此状态代码,这意味着不能回应请求所要求的任何资源。

502 非法网关(Bad Gateway)

作为网关或是兼任的服务器自要传送要求的下游(upstream)服务器接到非法的回应。

503 业务不能用(Service Unavailable)

服务器当前难以处置要求。这通常是因为服务器临时性故障或是保障引发的。该状态码暗示情况是暂时性的,要造成一些延迟。

留意:503状态码并且没表明服务器于超载时某种要回到此状态码。一些服务器也许期望于故障时使用直观处置,乃断掉相连。

IIS 错误代码大汇总

400 难以验证此请求。 401.1 不予许可|访问因为凭证违宪遭婉拒。

401.2 不予许可: 访问因为服务器安装倾向使用替代身份验证方法因而遭婉拒。

401.3 不予许可|访问因为 ACL 对于所要求资源的设置遭婉拒。

401.4 不予许可:Web 服务器上安装的筛选器许可失利。

401.5 不予许可:ISAPI/CGI 应用程序许可失利。

401.7 不予许可:因为 Web 服务器之上的 URL 授权策略因而婉拒采访。

403 严禁采访:采访遭婉拒。

403.1 严禁访问:履行采访遭婉拒。

403.2 严禁采访:读取采访遭婉拒。

403.3 严禁采访:写入采访遭婉拒。

403.4 严禁采访:需采用 SSL 察看该资源。

403.5 严禁采访:需采用 SSL 128 察看该资源。

403.6 严禁采访:客户端的 IP 地址遭婉拒。

403.7 严禁采访:需 SSL 客户端证书。

403.8 严禁采访:客户端的 DNS 名称遭婉拒。

403.9 严禁采访:甚余客户端试图连收到 Web 服务器。

403.10 严禁采访:Web 服务器安装为拒绝执行采访。

403.11 严禁采访:密码已经变更。

403.12 严禁访问:服务器证书映射器婉拒了客户端证书采访。

403.13 严禁采访:客户端证书已经于 Web 服务器之上注销。

403.14 严禁采访:于 Web 服务器之上已经婉拒目录列表。

403.15 严禁采访:Web 服务器已经少于客户端采访许可证约束。

403.16 严禁采访:客户端证书格式错误或是未曾遭 Web 服务器信赖。

403.17 严禁采访:客户端证书已届满或是未施行。

403.18 严禁访问:难以于当前应用程序池之中履行请求的 URL。

403.19 严禁访问:难以于该应用程序池之中作为客户端履行 CGI。

403.20 严禁采访:Passport 指定失利。

404 找绝不到文件或是目录。

404.1 文件或是目录未曾看到:网站难以于所要求的接口访问。

留意 404.1 错误仅会发生于具备多个 IP 地址的计算机之上。假如于特定 IP 地址/接口混合之上接到客户端要求,所以没把 IP 地址安装为于该特定的端口之上侦听,亦 IIS 返回 404.1 HTTP 错误。比如,假如一台计算机有两个 IP 地址,因而仅把其中一个 IP 地址安装为于端口 80 之上侦听,亦另一个 IP 地址自接口 80 接到的任何请求均把造成 IIS 返回 404.1 错误。仅应于此业务级别设立该错误,由于只当服务器之上采用余个 IP 地址时便会把它回到给客户端。

404.2 文件或是目录难以看到:锁定策略严禁该请求。

404.3 文件或是目录难以看到:MIME 态射策略严禁该请求。

405 用作采访该页的 HTTP 动作未曾遭授权。

406 客户端浏览器绝不接纳所要求页面的 MIME 类型。

407 Web 服务器需初始的代理验证。

410 文件已经移除。

412 客户端设立的前提条件于 Web 服务器之上检验时失利。

414 要求 URL 甚小,所以于 Web 服务器之上绝不接纳该 URL。

500 服务器外部错误。

500.11 服务器正确:Web 服务器之上的应用程序正在于拆除。

500.12 服务器正确:Web 服务器之上的应用程序正在于再次开启。

500.13 服务器正确:Web 服务器甚忙碌。

500.14 服务器正确:服务器之上的无效应用程序安装。

500.15 服务器正确:绝不容许间接要求 GLOBAL.ASA。

500.16 服务器正确:UNC 许可凭据绝不准确。

500.17 服务器正确:URL 许可储存难以看到。

500.18 服务器正确:URL 许可储存难以开启。

500.19 服务器正确:该文件的数据于安装数据库之中安装绝不准确。

500.20 服务器正确:URL 授权域难以看到。

500 100 外部服务器正确:ASP 错误。

501 标题值选定的配置没履行。

502 Web 服务器当作网关或是代理服务器时接到违宪的响应。