快速學習AngularJs HTTP響應攔截器_AngularJS

來源:互聯網
上載者:User

任何時候,如果我們想要為請求添加全域功能,例如身份認證、錯誤處理等,在請求發送給伺服器之前或伺服器返回時對其進行攔截,是比較好的實現手段。

angularJs通過攔截器提供了一個從全域層面進行處理的途徑。

四種攔截器

實現 request 方法攔截請求

request: function(config) {// do something on request successreturn config || $q.when(config);} 

該方法會在 $http 發送請求後台之前執行,因此你可以修改配置或做其他的操作。該方法接收請求設定物件(request configuration object)作為參數,然後必須返回設定物件或者 promise 。如果返回無效的設定物件或者 promise 則會被拒絕,導致 $http 調用失敗。

實現 requestError 方法攔截請求異常

requestError: function(rejection) {  // do something on request error  return $q.reject(rejection);} 

有時候一個請求發送失敗或者被攔截器拒絕了,請求異常攔截器會俘獲那些被上一個請求攔截器中斷的請求。它可以用來恢複請求或者有時可以用來撤銷請求之前所做的配置,比如說關閉進度條,啟用按鈕和輸入框什麼之類的。

實現 response 方法攔截響應

response: function(response) {  // do something on response successreturn response || $q.when(response);} 

該方法會在 $http 接收到從後台過來的響應之後執行,因此你可以修改響應或做其他動作。該方法接收響應對象(response object)作為參數,然後必須返迴響應對象或者 promise。響應對象包括了請求配置(request configuration),頭(headers),狀態(status)和從後台過來的資料(data)。如果返回無效的響應對象或者 promise 會被拒絕,導致$http 調用失敗。

實現 responseError 方法攔截響應異常

responseError: function(rejection) {// do something on response error  return $q.reject(rejection);} 

有時候我們後台調用失敗了,也有可能它被一個請求攔截器拒絕了或者被上一個響應攔截器中斷了。在這種情況下,響應異常攔截器可以協助我們恢複後台調用。

攔截器核心

攔截服務工廠

var app = angular.module("ajaxHttp", []);app.factory("httpInterceptor", [ "$q", "$rootScope", function($q, $rootScope) {return {request: function(config) {// do something on request successreturn config || $q.when(config);},   requestError: function(rejection) {     // do something on request error     return $q.reject(rejection)   },response: function(response) {// do something on response successreturn response || $q.when(response);},responseError : function(rejection) {// do something on response errorreturn $q.reject(rejection);}};}]); 

註冊攔截Factory 方法

app.config(["$httpProvider", function($httpProvider) {  $httpProvider.interceptors.push("httpInterceptor");}]); 

樣本

對401,404的攔截處理

app.config(["$httpProvider", function($httpProvider) { $httpProvider.interceptors.push('httpInterceptor'); }]); app.factory("httpInterceptor", ["$q", "$injector", function($q, $injector) {return {"responseError": function(response) {if (response.status == 401) {var rootScope = $injector.get('$rootScope');var state = $injector.get('$rootScope').$state.current.name;rootScope.stateBeforLogin = state;rootScope.$state.go("login");return $q.reject(response);}else if (response.status === 404) {console.log("404!");return $q.reject(response);}}};]);

以上內容給大家分享快速學習AngularJs HTTP響應攔截器 的相關知識,希望大家喜歡,同時感謝大家一直以來對雲棲社區網站的支援。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.