我将AngularJS用于我的应用程序和ui-route。我的应用程序中的服务如下所示:
(function() {
'use strict';
angular
.module('myProject.myModule')
.factory('myService', myService);
myService.$inject = ['$http', 'api_config'];
function myService($http, api_config) {
var service = {
myServiceMethod1: myServiceMethod1,
...
};
return service;
////////////
function myServiceMethod1(params) {
return $http.get(api_config.BASE_URL + '/path');
}
现在我将以这种方式实现(全局)拦截器,只要响应状态是HTTP 403,拦截器就应该处理它。 这个拦截器应该是全球性的。 非常感谢!
答案 0 :(得分:3)
尝试类似
的内容angular
.module('myProject.myModule')
.config(['$httpProvider', function ($httpProvider) {
$httpProvider.interceptors.push(['$q', '$location', function ($q, $location) {
return {
'responseError': function(response) {
if(response.status === 401 || response.status === 403) {
$location.path('/signin'); // Replace with whatever should happen
}
return $q.reject(response);
}
};
}]);
}]);