AngularJS_AngularJS における http インターセプトの詳細な説明

WBOY
リリース: 2016-05-16 15:15:57
オリジナル
2107 人が閲覧しました

http インターセプト、つまり $http サービスを使用すると、リクエストを行う前とレスポンスを受信した後に何かを実行したい場合があります。
$httpProvider にはインターセプターの配列が含まれています。

このようなインターセプターを作成します。

app.factory('myInterceptor', ['$log', function($log){
  $log.debug('');
  
  var myInterceptor = {};
  
  return myInterceptor;
}])
ログイン後にコピー

次にインターセプターを登録します。

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;
})
ログイン後にコピー

上記はリクエストのインターセプト、非同期操作が実行され、非同期操作の結果に従って設定が更新されます。

もちろん、応答傍受もあります。

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;
}])
ログイン後にコピー

■セッションインターセプト、リクエストインターセプト

サーバーには 2 種類の検証があり、1 つは Cookie に基づくもの、もう 1 つはトークンに基づくものです。トークンベースの認証の場合、ユーザーがログインすると、サーバーからトークンが取得され、このトークンがリクエストごとにサーバーに送信されます。

セッションに関連するインジェクターを作成します:

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;
}])
ログイン後にコピー

サーバーから返されたトークンが config.headers に配置されていることがわかります。

インジェクターを登録します:

app.config(['$httpProvider', function($httpProvider){
  $httpProvider.interceptors.push('sessionInjector');
}])
ログイン後にコピー

リクエストを行う:

$http.get('');
ログイン後にコピー

迎撃前のおおよその状況は次のとおりです:

{
  "transformRequest":[null],
  "transformResponse":[null],
  "method":"GET",
  "url":"",
  "headers":{
    "Accept": "application/json, text/plain,*/*"
  }
}

ログイン後にコピー

インターセプト後、ヘッダーにさらに 2 つの 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.requestTimestamp と config.responseTimestamp に割り当てます。

インターセプタを登録します:

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;
}])
ログイン後にコピー

以上がこの記事の全内容です。皆様の学習のお役に立てれば幸いです。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート