使用Javascript跟踪长期和失败的请求

时间:2013-11-08 10:04:15

标签: javascript ajax logging error-handling

有时我的应用程序表现得很奇怪。我的一些请求开始需要很长时间,然后可能会失败,没有任何系统。甚至在查看日志之后我也找不到这样的请求,看起来它们甚至没有被服务器处理。

所以我想实现客户端脚本,他们将跟踪长期或失败的请求,然后将此信息发送到服务器。

实现此类功能的最佳方法是什么?

1 个答案:

答案 0 :(得分:2)

(1)您可以覆盖XMLHttpRequest以提供所需的功能。

var mylog = [];    

XMLHttpRequest = (function(XMLHttpRequest) {
    return function() {
        XMLHttpRequest.apply(this, arguments);
        this.timeout = 30 * 1000; //thirty seconds
        this.ontimeout = function() {
            mylog.push("Request timed out");
        };
    };
})(XMLHttpRequest);

setInterval(function() {
    //send to server
    mylog = [];
}, 60 * 1000);

(2)您可以创建自己的XHR工厂,在其上设置timeoutontimeout。您可以更改所有代码以使用它。

(3)你没有提到jQuery,所以我不会花太多时间在这上面,但是使用jQuery,你可以使用$.ajaxSetup来设置默认参数。

实际上,你应该花时间尝试从服务器端跟踪这个;他们在收集你想要的东西时更加可靠。