Angular JS Interceptor处理HTTP错误状态

时间:2015-11-26 15:39:11

标签: javascript angularjs interceptor

我将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,拦截器就应该处理它。 这个拦截器应该是全球性的。 非常感谢!

1 个答案:

答案 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);
            }
        };
    }]);
}]);