淺析AngularJs HTTP響應(yīng)攔截器
為何要用攔截器?
任何時候,如果我們想要為請求添加全局功能,例如身份認(rèn)證、錯誤處理等,在請求發(fā)送給服務(wù)器之前或服務(wù)器返回時對其進(jìn)行攔截,是比較好的實(shí)現(xiàn)手段。
angularJs通過攔截器提供了一個從全局層面進(jìn)行處理的途徑.
攔截器允許你:
通過實(shí)現(xiàn) request 方法攔截請求: 該方法會在 $http 發(fā)送請求道后臺之前執(zhí)行,因此你可以修改配置或做其他的操作。該方法接收請求配置對象(request configuration object)作為參數(shù),然后必須返回配置對象或者 promise 。如果返回?zé)o效的配置對象或者 promise 則會被拒絕,導(dǎo)致 $http 調(diào)用失敗。
通過實(shí)現(xiàn) response 方法攔截響應(yīng): 該方法會在 $http 接收到從后臺過來的響應(yīng)之后執(zhí)行,因此你可以修改響應(yīng)或做其他操作。該方法接收響應(yīng)對象(response object)作為參數(shù),然后必須返回響應(yīng)對象或者 promise。響應(yīng)對象包括了請求配置(request configuration),頭(headers),狀態(tài)(status)和從后臺過來的數(shù)據(jù)(data)。如果返回?zé)o效的響應(yīng)對象或者 promise 會被拒絕,導(dǎo)致$http 調(diào)用失敗。
通過實(shí)現(xiàn) requestError 方法攔截請求異常: 有時候一個請求發(fā)送失敗或者被攔截器拒絕了。請求異常攔截器會俘獲那些被上一個請求攔截器中斷的請求。它可以用來恢復(fù)請求或者有時可以用來撤銷請求之前所做的配置,比如說關(guān)閉進(jìn)度條,激活按鈕和輸入框什么之類的。
通過實(shí)現(xiàn) responseError 方法攔截響應(yīng)異常: 有時候我們后臺調(diào)用失敗了。也有可能它被一個請求攔截器拒絕了,或者被上一個響應(yīng)攔截器中斷了。在這種情況下,響應(yīng)異常攔截器可以幫助我們恢復(fù)后臺調(diào)用。
攔截器的核心是服務(wù)工廠,通過向$httpprovider.interceptors數(shù)組中添加服務(wù)工廠。在$httpProvider中進(jìn)行注冊。
angularJs提供四種攔截器,其中兩種成功攔截器(request、response),兩種失敗攔截器(requestError、responseError)。
在服務(wù)中添加一種或多種攔截器:
angular.module("myApp", [])
.factory('httpInterceptor', [ '$q', '$injector',function($q, $injector) {
var httpInterceptor = {
'responseError' : function(response) {
......
return $q.reject(response);
},
'response' : function(response) {
......
return response;
},
'request' : function(config) {
......
return config;
},
'requestError' : function(config){
......
return $q.reject(config);
}
}
return httpInterceptor;
}
然后使用$httpProvider在.config()函數(shù)中注冊攔截器
angular.module("myApp", [])
.config([ '$httpProvider', function($httpProvider) {
$httpProvider.interceptors.push('httpInterceptor');
} ]);
實(shí)際的例子:(對401、404的攔截)
routerApp.config([ '$httpProvider', function($httpProvider) {
$httpProvider.interceptors.push('httpInterceptor');
} ]);
routerApp.factory('httpInterceptor', [ '$q', '$injector',function($q, $injector) {
var httpInterceptor = {
'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) {
alert("404!");
return $q.reject(response);
}
},
'response' : function(response) {
return response;
}
}
return httpInterceptor;
}
]);
Session 注入(請求攔截器)
這里有兩種方式來實(shí)現(xiàn)服務(wù)端的認(rèn)證。第一種是傳統(tǒng)的 Cookie-Based 驗證。通過服務(wù)端的 cookies 來對每個請求的用戶進(jìn)行認(rèn)證。另一種方式是 Token-Based 驗證。當(dāng)用戶登錄時,他會從后臺拿到一個 sessionToken。sessionToken 在服務(wù)端標(biāo)識了每個用戶,并且會包含在發(fā)送到服務(wù)端的每個請求中。
下面的 sessionInjector 為每個被俘獲的請求添加了 x-session-token 頭 (如果當(dāng)前用戶已登錄):
<!-- lang: js -->
module.factory('sessionInjector', ['SessionService', function(SessionService) {
var sessionInjector = {
request: function(config) {
if (!SessionService.isAnonymus) {
config.headers['x-session-token'] = SessionService.token;
}
return config;
}
};
return sessionInjector;
}]);
module.config(['$httpProvider', function($httpProvider) {
$httpProvider.interceptors.push('sessionInjector');
}]);
然后創(chuàng)建一個請求:
<!-- lang: js -->
$http.get('https://api.github.com/users/naorye/repos');
被 sessionInjector 攔截之前的配置對象是這樣的:
<!-- lang: js -->
{
"transformRequest": [
null
],
"transformResponse": [
null
],
"method": "GET",
"url": "https://api.github.com/users/naorye/repos",
"headers": {
"Accept": "application/json, text/plain, */*"
}
}
被 sessionInjector 攔截之后的配置對象是這樣的:
<!-- lang: js -->
{
"transformRequest": [
null
],
"transformResponse": [
null
],
"method": "GET",
"url": "https://api.github.com/users/naorye/repos",
"headers": {
"Accept": "application/json, text/plain, */*",
"x-session-token": 415954427904
}
}
以上內(nèi)容給大家介紹了AngularJs HTTP響應(yīng)攔截器的相關(guān)知識,希望本文分享能夠給大家?guī)韼椭?/p>
- 詳解AngularJS用Interceptors來統(tǒng)一處理HTTP請求和響應(yīng)
- angular中的http攔截器Interceptors的實(shí)現(xiàn)
- angular 用攔截器統(tǒng)一處理http請求和響應(yīng)的方法
- AngularJS使用攔截器實(shí)現(xiàn)的loading功能完整實(shí)例
- 詳解AngularJs HTTP響應(yīng)攔截器實(shí)現(xiàn)登陸、權(quán)限校驗
- 快速學(xué)習(xí)AngularJs HTTP響應(yīng)攔截器
- 分享Angular http interceptors 攔截器使用(推薦)
相關(guān)文章
AngularJS自定義服務(wù)與fliter的混合使用
這篇文章主要介紹了AngularJS自定義服務(wù)與fliter的混合使用的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-11-11
Angular使用$http.jsonp發(fā)送跨站請求的方法
這篇文章主要介紹了Angular使用$http.jsonp發(fā)送跨站請求的方法,結(jié)合實(shí)例形式分析了$http.jsonp發(fā)送跨站請求遇到的問題與相應(yīng)的解決方法,具有一定參考借鑒價值,需要的朋友可以參考下2017-03-03
AngularJS之ionic 框架下實(shí)現(xiàn) Localstorage本地存儲
這篇文章主要介紹了AngularJS之ionic 框架下實(shí)現(xiàn) Localstorage本地存儲,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
angular 基于ng-messages的表單驗證實(shí)例
本篇文章主要介紹了angular 基于ng-messages的表單驗證實(shí)例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解 (上)
這篇文章主要給大家介紹了關(guān)于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來看看吧。2017-07-07

