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请求和响应的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。