状态码为0是什么意思?它是否意味着在所有浏览器和所有HTTP客户端实用程序相同的事情?它是HTTP规范的一部分还是其它协议规范的一部分?这似乎意味着HTTP请求根本不能做,也许是因为服务器地址无法解决。
什么错误消息适合显示用户? “你没有连接到互联网,或者网站遇到问题,或者地址中可能有输入错误”?
我应该补充一点,我看到FireFox当设置为“脱机工作”,但不是在Microsoft Internet Explorer中设置为“脱机工作”时的行为。在IE中,用户获得一个对话框,提供上线选项。 FireFox不会在返回错误之前通知用户。
我要求这是响应“显示更好的错误消息”的请求。什么Internet Explorer是好的。它告诉用户导致问题的原因,并给他们选择修复它。为了给一个等效的UX与FireFox我需要推断问题的原因并通知用户。那么,我可以从状态0推断出什么?它有一个普遍的意义,还是告诉我什么?
它不是一个HTTP响应代码,但它被记录为W3作为XMLHttpRequest的status属性(因此也是一个jqXHR对象,对于jQuery用户)的有效值。
它涵盖了一系列可能的情况,其中没有可用于报告的真正的HTTP响应代码,因为您没有发送请求,您明确中止了它,页面正在卸载,或者x出现了许多可能的值之一的x。
长答案
首先重申一下:0不是HTTP状态码。在RFC 7231 Section 6.1中有一个完整的列表,不包括0,第6节的介绍清楚地说明了
The status-code element is a three-digit integer code
其中0不是。
但是,记录了作为XMLHttpRequest对象的status属性的值的0。从http://www.w3.org/TR/XMLHttpRequest/#the-status-attribute的文档:
4.7.1 The status attribute
The
status
attribute must return the result of running these steps:
If the state is UNSENT or OPENED,return 0.
If the error flag is set,return 0.
Return the HTTP status code.
我们可以深入了解规范,找出那些条件返回0意味着什么。从http://www.w3.org/TR/XMLHttpRequest/#states:
4.5 States
…
UNSENT
(numeric value 0)The object has been constructed.
OPENED
(numeric value 1)The
open()
method has been successfully invoked. During this state request headers can be set usingsetRequestHeader()
and the request can be made using thesend()
method.…
The error flag indicates some type of network error or fetch termination. It is initially unset.
还需要注意的是,UNSENT和OPENED之后的下一个可能状态是HEADERS_RECEIVED:
HEADERS_RECEIVED
(numeric value 2)All redirects (if any) have been followed and all HTTP headers of the final response have been received. Several response members of the object are now available.
将这些都放在一起,简短的回答是,0是简单的XMLHttpRequest对象的status属性返回的,当没有真正的状态代码返回时,因为:
>请求尚未发送,或
>请求已发送,但响应的标头尚未收到,或
>发生了在the docs中列出的导致“错误标志”被设置的许多可能情况之一。
好吧,但什么错误可以导致这个神秘的“错误标志”设置?如果你在W3文档中使用CTRL-F作为’错误标志’,你会发现它在发送请求时被取消设置,并且它只被设置为“终止请求”的算法的一部分。寻找算法被调用的所有地方,你会发现它发生在:
>使用open()方法打开(或重新打开)请求
>请求是垃圾回收(例如离开页面时)
>使用abort()方法中止请求
>发生“请求错误”,这可能发生在以下情况之一时:
>发生网络错误,如果发生,可能会发生
>有一个无限重定向循环
>有/有
DNS errors,TLS negotiation failure,or other type of network error
>请求是CORS请求,并且无法共享响应
>发生中止错误,只有在发生时才会发生
The end user cancels the request
无论这意味着什么。我不知道有什么浏览器显示用户当AJAX请求发生,并给他们明确取消他们的机会,所以我认为这是 – 至少今天是不相关的。
>发生超时错误,这意味着,足够了
07004 is not 0 and since the request started the amount of milliseconds specified by
timeout
has passed
只要XMLHttpRequest去,那就是一切。
除了XMLHttpRequest,我会推测,JavaScript之外的语言的HTTP库可能使用类似的0状态码作为默认值,当没有从服务器接收到状态码。