angular中的http拦截器Interceptors
2024-08-24 11:00:30
在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');
}
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 的各类自定义错误
最新文章
- Screeps ———— A MMO Strategy Sandbox Game for Programmers
- 【温故而知新-Javascript】使用拖放
- Swift3.0语言教程使用路径字符串
- Unity 3D中的内存管理
- 为移动Web应用创建快速响应按钮
- 戴尔笔记本win8.1+UEFI下安装Ubuntu14.04过程记录
- Java程序员快速入门Go语言
- 当 ReactJS 遇到 TypeScript
- openFace 人脸识别框架测试
- 平方根的C语言实现(三) ——最终程序实现
- 时间规划在Optaplanner上的实现
- Yolov3参数解释以及答疑
- Python的itertools模块
- sqlserver--install/uninstall
- 带你走进EJB--将EJB发布为Webservice(2)
- VMware11 安装MAC OS X 10.9
- service几种访问类型(集群外负载均衡访问LoadBalancer , 集群内访问ClusterIP,VPC内网负载均衡LoadBalancer ,集群外访问NodePort)
- pyhton 函数参数,递归函数,高阶函数(一点点笔记)
- nginx 路由配置
- [StringUtil ] isEmpty VS isBlank
热门文章
- 跟我一起玩Win32开发(19):浏览和打开文件
- [SDOI2016]模式字符串
- Wolfycz的娱乐赛题解
- h5-20-文件操作-拖放文件
- A. The Fault in Our Cubes 暴力dfs
- js操作css样式、js的兼容问题
- Arduino中数据类型转换 float/double转换为char 亲测好使,dtostrf()函数
- 10个顶级的CSS3代码生成器
- Sql Server 2012 分页方法分析(offset and fetch)
- http接口调用,传递json格式带双引号问题