Javascript 在拦截中召回$resource工厂

Javascript 在拦截中召回$resource工厂,javascript,angularjs,interceptor,angular-resource,angular-services,Javascript,Angularjs,Interceptor,Angular Resource,Angular Services,我有以下工厂: .factory('Request', ['$resource', 'general', function ($resource) { return $resource(baseURL + ':resourceName/', {}, { get : { method : 'GET', isArray : true,

我有以下
工厂

.factory('Request', ['$resource', 'general',
        function ($resource) {
            return $resource(baseURL + ':resourceName/', {}, {
                get : {
                    method : 'GET',
                    isArray : true,
                    transformResponse : function (data, headers) {
                        return JSON.parse(data).data;
                    },
                    interceptor: {
                        responseError : function (data) {
                            gnrl.logIn({},false,function(){console.log("test");});
                            // ???? How to recall this request? 
                        }
                    }
                }
            });
        }
    ]);
我想做的是,如果用户在这个请求中遇到了一些问题,那么用户应该再次登录,请求应该再次执行

请求工厂的调用方式如下:

Request.get(params, headers, function (res) {
    //does some operation with results  
});
general.doRequest(3, params/*parameters used in request*/, function (res) {
            /***cb function for your initially request*/
});

我看到了,但没有一个能完全符合我的情况。

这是用问题中提到的答案解决的。如前所述,主要思想是使用
$promise
而不是
拦截器

我已经解决了以下问题:

Request.get(params, headers, function (res) {
    //does some operation with results  
});
general.doRequest(3, params/*parameters used in request*/, function (res) {
            /***cb function for your initially request*/
});
以下是我服务中的一项功能

self.doRequest = function(nOfRetries, params, successFunction) {
        function fai(a) {
            nOfRetries--;
            self.logIn(function(){self.doRequest(nOfRetries);});
        }
        if (nOfRetries >= 0) {
            Request.get(params).then(successFunction).catch(fai);
        }
    }
Login
只是同一服务中的另一个函数,作为回调函数,我向该函数发送请求

doRequest
的调用如下:

Request.get(params, headers, function (res) {
    //does some operation with results  
});
general.doRequest(3, params/*parameters used in request*/, function (res) {
            /***cb function for your initially request*/
});
最后,您将看到
请求
工厂:

.factory('Request', ['$resource',
        function ($resource) {
            var res = $resource(baseURL + ':resourceName/', {}, {
                    get : {
                        method : 'GET'
                    }
                });
            return {
                get : function (arguments) {
                    return res.get(arguments).$promise;
                }
            };
        }
    ])
请注意,
doRequest的
success回调函数中出现的任何错误(服务器端或非服务器端)也将导致执行失败回调函数