angular中的http拦截器Interceptors的实现
程序员文章站
2022-04-09 22:58:22
在angularjs中增加了一个对全局的http请求统一做出处理的api--interceptors
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'); } 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 的各类自定义错误
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。