欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

angular 用拦截器统一处理http请求和响应的方法

程序员文章站 2022-04-10 10:15:56
想使用angularjs里的htpp向后台发送请求,现在有个用户唯一识别的token想要放到headers里面去,也就是{headres:{'token':1}} ind...

想使用angularjs里的htpp向后台发送请求,现在有个用户唯一识别的token想要放到headers里面去,也就是{headres:{'token':1}}

index.html里引入以下js:

angular.module('app.factorys',[])
  .factory('httpinterceptor',['$q','$injector','$localstorage',function ($q,$injector,$localstorage) {
    var httpinterceptor = {
      'responseerror' : function(response) {
        // ......
        return $q.reject(response);
      },
      'response' : function(response) {
        if (response.status == 21000) {
          // console.log('do something...');
        }
        return response || $q.when(response);
      },
      'request' : function(config) {
        config.headers = config.headers || {};
        if ($localstorage.token) {
          config.headers.token = $localstorage.token;
          // config.headers['x-access-token'] = $localstorage.token;
        };

        return config || $q.when(config);

        return config;
      },
      'requesterror' : function(config){
        // ......
        return $q.reject(config);
      }
    };
    return httpinterceptor;
  }])

在app里注入factory后,在config里面配置

.config(['$httpprovider',function(){
  $httpprovider.interceptors.push(httpinterceptor);
}])

以上这篇angular 用拦截器统一处理http请求和响应的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。