您好,登錄后才能下訂單哦!
在angularJs中增加了一個對全局的http請求統一做出處理的api--interceptors
Interceptors 有兩個處理時機,分別是:
其引用場景包括
使用實例如下:
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 ,這個四個方法非必選,可根據需要調用,前兩個是請求的前置處理,后兩個是針對請求的響應的處理。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。