Why XmlHttpRequest readyState = 2 on 200 HTTP response code
所以我使用纯 javascript(没有 jquery)将文件发送到服务器。服务器脚本 PHP 最后返回状态码 200,但 javascript 正在准备就绪状态 == 2.
PHP 代码返回状态码 200:
1
2 |
header(‘X-PHP-Response-Code: 200’, true, 200);
exit; |
javascript 正在做的事情:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
request.onreadystatechange = function() {
if (request.readyState == 4) { var message; switch(request.status) { case ‘200’: message =“Data uploaded successfully.”; break; case ‘406’: case ‘410’: default: request.send(formData); |
即使知道 HTTP 200 状态代码在前端正确返回(我得到”OK”)。 JS 脚本看到 readyState==2 (即 else 块总是命中)
我的理解是服务器状态码 200 应该给 readyState == 4??
首先,onreadystate 不只是被触发一次。它被触发了多次,你需要能够处理它。这些是您需要处理的代码:
0 UNSENT – open() 尚未被调用
1 OPENED – 尚未调用 send()
2 HEADERS_RECEIVED – send() 已被调用,并且标头和状态可用
3 LOADING 下载; – responseText 保存部分数据
4 – 操作完成
您的代码正在点击 readyState == 2 上的 else 块(收到的标头)并假设它不是错误状态。
你的错误检查应该在 request.readyState == 4 检查里面。这样,请求就完成了,但也可能出现错误:
1
2 3 4 5 6 7 8 9 10 |
if (request.readyState == 4) {
switch(request.status) { case ‘200’: message =“Data uploaded successfully.”; break; // Error handling here default: alert(“Unexpected error: “ + this.statusText +“.\ Please try again”); break; } } |
https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest
- 我意识到 onreadystate 多次命中 – 实际上随时 readyState 变化。具体来说,我想知道为什么当我发回 HTTP 200 时 readyState 不是 4?到时候操作不是完成了吗?如果不是,服务器脚本必须给出什么指标才能获得 readyState == 4?编辑:您的代码将失败,因为 HTTP 状态 200 上的 readyState == 2。
- 您的 readyState 最终可能确实命中了已完成的块。只是它在收到错误时会首先击中”错误”部分。当收到响应时,它应该总是收到一个完成 – 无论它的错误是否由它的响应代码定义。更新答案以更好地解释
- 我的代码不会失败。当返回任何状态码时,readyState 为 2(接收到标头时)和 4(已下载响应时)。
来源:https://www.codenong.com/26419888/