angular中的http拦截器Interceptors的实现
网络编程 2021-07-04 19:20www.168986.cn编程入门
本篇文章主要介绍了angular中的http拦截器Interceptors的实现的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
在angularJs中增加了一个对全局的http请求统一做出处理的api--interceptors
Interceptors 有两个处理时机,分别是
- 其它程序代码执行 HTTP 请求之后,在实际从浏览器发出请求之前,即处理请求
- 得到请求的响应之后,在交给其它程序代码处理之前,即处理请求的响应
其引用场景包括
- 全局处理错误
- 统一进行身份验证一类的处理
- 对所有发出去的请求进行预处理
- 对所有收到的响应进行预处理等等
使用实例如下
monService.config(['$httpProvider',function($httpProvider){ //$httpProvider.defaults.headers.mon = {'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'); } 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 错误,如服务器没有响应时,或者 PHP 之类的 CGI 经常出现的 502 一类,还可以处理 HTTP 状态码不是 200 的各类自定义错误
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:微信小程序 扎金花简单实例
下一篇:微信小程序 PHP生成带参数二维码
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程