AnglarJSのhttpブロックについて詳しく説明してください。
6583 ワード
httpブロックとは、httpサービスがサービスと対話することを許可しています。時々私たちは要求を出す前に、そして応答を受けてから何かをしたいです。http Providerはinterceptorsの配列を含んでいます。
私たちはこのようにインタフェースを作成します。
■インターロック中の非同期操作
もちろん応答ブロックもあります。
サービス側には2種類の検証があり、一つはクッキーに基づいており、一つはtokenに基づくものである。token検証に基づいて、ユーザがログインすると、サービス端末からtokenを取得し、このtokenは、要求毎にサービス端末に送信する。
sessionに関するinjectorを作成します。
登録injector:
登録ブロック:
要求ブロックのエラー状況をシミュレーションします。
私たちはこのようにインタフェースを作成します。
app.factory('myInterceptor', ['$log', function($log){
$log.debug('');
var myInterceptor = {};
return myInterceptor;
}])
次にinterceptorを登録します。
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('myInterceptor');
}])
以下はhttpブロックのいくつかの例です。■インターロック中の非同期操作
app.factory('myInterceotpr','someAsyncServcie', function($q, someAsyncServcie){
var requestInterceptor = {
request: function(config){
var deferred = %q.defer();
someAsyncService.doAsyncOperation().then(function(){
...
deferred.resolve(config);
}, function(){
...
deferred.resolve(config);
})
return deferred.promise;
}
};
return requestInterceptor;
})
以上は、要求ブロックであり、非同期操作を行い、非同期操作の結果によってconfigを更新する。もちろん応答ブロックもあります。
app.factory('myInterceptor',['$q', 'someAsyncService', function($q, someAsyncSercice){
var responseInterceptor = {
response: function(response){
var deferred = $q.defer();
someAsyncService.doAsyncOperation().then(function(response){
...
deferred.resolve(response);
}, function(response){
...
deferred.resolve(response);
})
return deferred.promise;
}
};
return responseInterceptor;
}])
■Sessionブロック、ブロックをお願いします。サービス側には2種類の検証があり、一つはクッキーに基づいており、一つはtokenに基づくものである。token検証に基づいて、ユーザがログインすると、サービス端末からtokenを取得し、このtokenは、要求毎にサービス端末に送信する。
sessionに関するinjectorを作成します。
app.factory('sessionInjector',['SessionService', function(SessionService){
var sessionInjector = {
request: function(config){
if(!SessionService.isAnonymous){
config.headers['x-session-token'] = SessionService.token;
}
return config;
}
};
return sessionInjector;
}])
従って、サービスから戻ってきたtokenをconfig.headersに置いていることが分かります。登録injector:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('sessionInjector');
}])
要求を出す:
$http.get('');
ブロックする前に大体:
{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*"
}
}
ブロック後、headersの中に一つのx-session-tokenフィールドが二つあります。
{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*",
"x-session-token":......
}
}
■タイムスタンプ、要求と応答ブロック
app.factory('timestampMarker',[function(){
var timestampMarker = {
request:function(config){
config.requestTimestamp = new Date().getTime();
return config;
},
response: function(response){
response.config.responseTimestamp = new Date().getTime();
return config;
}
};
return timestampMarker;
}])
以上、要求と応答時にブロッキングし、config.request Timestampとconfig.reponseTimestamp賦上の現在の時間。登録ブロック:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('timestampMarker');
}])
そして、運用時に応答を求める時間を算出することができます。
$http.get('').then(function(response){
var time = response.config.responseTime - response.config.requestTimestamp;
console.log(' ' + time);
})
■エラー回復を要求し、ブロックを要求する要求ブロックのエラー状況をシミュレーションします。
app.factory('requestRejector',['$q', function($q){
var requestRejector = {
request: function(config){
return $q.reject('requestRejector');
}
};
return requestRejector;
}])
ブロック要求エラー:
app.factory('requestRecoverer',['$q', function($q){
var requestRecoverer = {
requestError: function(rejectReason){
if(rejectReason === 'requestRejector'){
//
return {
transformRequest:[],
transformResponse:[],
method:'GET',
url:'',
headers:{
Accept:'application/json, text/plain, */*'
}
};
} else {
return $q.reject(rejectReason);
}
}
};
return requestRecoverer;
}])
登録ブロック:
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('requestRejector');
$httpProvider.interceptors.push('requestRecoverer');
}])
■セッションエラー復旧、応答ブロック
app.factory('sessionRecoverer',['$q','$injector',function($q, $injector){
var sessionRecoverer = {
responseError: function(response){
// Session
if(response.status == 419){
var SessionService = $injector.get('SessionService');
var $http = $injector.get('$http');
var deferred = $q.defer();
// session
SessionService.login().then(deferred.resolve, deferred.reject);
return deferred.promise.then(function(){
reutrn $http(response.config);
})
}
return $q.reject(response);
}
};
return sessionRecoverer;
}])
以上が本文の全部です。皆さんの勉強に役に立ちたいです。