angular中的http拦截器Interceptors的实现

网友投稿 276 2023-06-09


angular中的http拦截器Interceptors的实现

在angularjs中增加了一个对全局的http请求统一做出处理的api--interceptors

Interceptors 有两个处理时机,分别是:

其它程序代码执行 HTTP 请求之后,在实际从浏览器发出请求之前,即处理请求

得到请求的响应之后,在交给其它程序代码处理之前,即处理请求的响应

其引用场景包括

全局处理错误

统一进行身份验证一类的处理

对所有发出去的请求进行预处理

对所有收到的响应进行预处理等等

使用实例如下:

commonService.config(['$httpProvider',function($httpProvider){

//$httpProvider.defaults.headers.common = {'X-Auth-Token': $.cookie('x_auth_token'),'Content-Type':'application/json;charset=UTF-8'};

//添加拦截器;

$httpProvider.interceptors.push(function ($q) {

return {

request: function (obj) {

$('.loading').show();

obj.headers['X-Auth-Token'] = $.cookie('x_auth_token');

if(!obj.headers['Content-Type'])

obj.headers['Content-Type'] = 'application/json;charset=UTF-8';

var url, params,method;

//加盟店请求

mylog('jiamengdian::',sessionStorage.getItem("chainStorefrnId"));

if(sessionStorage.getItem("chainStorefrnId")){

//增加操作人id,name和storeid等信息

//操作人姓名

var operatorName = $.cookie("userType") == "employee" ? decodeURI($.cookie("username")) : decodeURI($.cookie("frnName"));

//操作人id

var operatorId = $.cookie("userId");

//加盟店id

var operatorStoreId = $.cookie("frnId");

if (obj.method) {

method = obj.method.toLowerCase();

} else {

method = "get";

}

//处理url,区分首次授信还是追加授信

var flag_url = sessionStorage.getItem('chainStoreFlag');

mylog('flag_url',flag_url);

if(flag_url && flag_url == "firstcredit"){

//提交需要加上加盟店标识

if(obj.url.indexOf("firstcredit/createPerFirstCredit")!=-1){

//标识个人提交

obj.url = obj.url.replace('firstcredit/createPerFirstCredit','firstcredit/perFirstCreditByFranchisee');

http:// }

else if(obj.url.indexOf("firstcredit/createBusiFirstCredit")!=-1){

//标识企业提交

obj.url = obj.url.replace('firstcredit/createBusiFirstCredit','firstcredit/createBusiFirstCreditByFranchisee');

}

} else {

url = obj.url + "?creditType=1&operatorName=" + operatorName + "&operatorId=" + operatorId + "&operatorStoreId=" + operatorStoreId;

}

}

return obj;

},

response: function (res) {

$(".loading").hide();

return res;

},

responseError: function (err) {

$(".loading").hide();

return $q.reject(err);

}

};

});

}]);

改api共有4个方法,分别为request ,requestError ,response ,responseError ,这个四个方法非必选,可根据需要调用,前两个是请求的前置处理,后两个是针对请求的响应的处理。

request :接收一个参数,它是 $http 中的标准 config 对象,同时也需要返回一个标准 config ,此时可以添加各类身份验证信息,同时也可在此启动进度条

requestError :当有多个 Interceptor 的时候, requestError 会在前一个 Interceptor 抛出错误或者执行 $q.reject() 时执行,接收的参数就对应的错误

response :接受一个请求对象参数,可以不处理就直接返回,此时也可以将进度条显示为成功完成,当然,如果后端 API 返回自定义错误时,HTTP 的状态码仍然是 200 得话,便在这里处理自定义错误,也可以对返回数据做一些处理,注意要将进度条置为完成

responseError :这个是重头戏,即可以处理标准的 Http 错误,如服务器没有响http://应时,或者 php 之类的 CGI 经常出现的 502 一类,还可以处理 HTTP 状态码不是 200 的各类自定义错误


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序 扎金花简单实例
下一篇:微信小程序 基础组件与导航组件详细介绍
相关文章

 发表评论

暂时没有评论,来抢沙发吧~