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回调函数中出现的任何错误(服务器端或非服务器端)也将导致执行失败回调函数