【问题标题】:Catch a 404 error for XHR捕获 XHR 的 404 错误
【发布时间】:2021-11-09 18:01:38
【问题描述】:

基本上,我必须创建一个 javascript APP 对象,它将对服务器的一系列异步请求进行排队,处理对 JSON 的响应,并从中记录错误。

JSON 处理错误很容易被“try-catch”捕获,但是像 404、500 等服务器错误仍然显示在浏览器的控制台中,而我需要在“APP.history”中静默记录。

我尝试通过下面的代码来实现它,但没有一个 404 错误会引发一个错误。我做错了什么?

xhr = new XMLHttpRequest();
xhr.open("GET", url, true)
xhr.onerror = function(){console.log("error")}  
xhr.upload.onerror = function(){console.log("error")}

顺便问一下,jQuery AJAX怎么能做到呢?

【问题讨论】:

标签: javascript jquery ajax


【解决方案1】:

404 状态不会触发 xhr.onerror() 因为从技术上讲它不是错误; 404 本身就是一个有效的响应。

一种解决方案是使用 loadend() 处理程序,无论如何都会触发。然后检查 404 的状态,或您感兴趣的任何状态。

xhr = new XMLHttpRequest();
xhr.open("GET", url, true);

xhr.onloadend = function() {
    if(xhr.status == 404) 
        throw new Error(url + ' replied 404');
}

XMLHttpRequestUpload 也有同样的方法。 不幸的是,我们的浏览器供应商不允许我们在 2017 年以编程方式抑制网络错误。However, networks errors can be suppressed using the console's filtering options.

【讨论】:

  • @Tesmen 应该将此答案设为正确答案,因为 404 不是错误。这是一个响应代码。此外,这个答案对我有用。
  • @Duco 不幸的是,在 event.target.readystate==1 和 event.target.readystate==2 之间的控制台级别报告了错误;在“loadend”发挥作用之前的方式。控制台的输出发生在 就绪状态事件之间;因此,当 readystate==2 通知我们情况时,一条消息(红色墨水)已经喷溅到控制台上。这就是您所说的“我们的浏览器供应商不允许我们以编程方式压制”的意思吗?如果是这样,感谢您解释为什么我无法清理它。
  • 这就是我的意思 IAM_AL_X。用户可以使用开发工具中的过滤器选项停止红色墨水,但程序员无法控制。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2013-02-18
  • 1970-01-01
  • 2017-03-16
  • 2016-11-12
  • 2017-03-12
  • 2012-05-10
相关资源
最近更新 更多