首頁 web前端 js教程 淺析AngularJs HTTP回應攔截器_AngularJS

淺析AngularJs HTTP回應攔截器_AngularJS

May 16, 2016 pm 03:23 PM
angularjs 攔截器

為何要用攔截器?

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

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

 攔截器允許你:

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

透過實作 response 方法攔截回應: 此方法會在 $http 接收到從背景過來的回應之後執行,因此你可以修改回應或做其他操作。此方法接收回應物件(response object)作為參數,然後必須傳回回應物件或 promise。回應物件包括了請求配置(request configuration),頭(headers),狀態(status)和從後台過來的資料(data)。如果傳回無效的回應物件或 promise 會被拒絕,導致$http 呼叫失敗。

透過實作 requestError 方法攔截請求異常: 有時候一個請求發送失敗或被攔截器拒絕了。請求異常攔截器會俘虜那些被上一個請求攔截器中斷的請求。它可以用來恢復請求或有時可以用來撤銷請求之前所做的配置,比如說關閉進度條,激活按鈕和輸入框什麼之類的。

透過實作 responseError 方法攔截回應異常: 有時候我們後台呼叫失敗了。也有可能它被一個請求攔截器拒絕了,或是被上一個回應攔截器中斷了。在這種情況下,響應異常攔截器可以幫助我們恢復後台呼叫。

 攔截器的核心是服務工廠,透過向$httpprovider.interceptors陣列中新增服務工廠。在$httpProvider中進行註冊。

 angularJs提供四種攔截器,其中兩種成功攔截器(request、response),兩種失敗攔截器(requestError、responseError)。

  在服務中增加一種或多種攔截器:

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()函數中註冊攔截器

angular.module("myApp", []) 
.config([ '$httpProvider', function($httpProvider) { 
  $httpProvider.interceptors.push('httpInterceptor'); 
} ]); 
登入後複製

  實際的例子:(對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 注入(請求攔截器)

這裡有兩種方式來實現服務端的認證。第一種是傳統的 Cookie-Based 驗證。透過服務端的 cookies 來對每個請求的使用者進行認證。另一種方式是 Token-Based 驗證。當使用者登入時,他會從後台拿到一個 sessionToken。 sessionToken 在服務端標識了每個用戶,並且會包含在發送到服務端的每個請求中。

下面的 sessionInjector 為每個被捕獲的請求添加了 x-session-token 頭 (如果當前用戶已登入):

<!-- 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');
}]);
登入後複製

然後建立一個請求:

<!-- 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
  }
}
登入後複製

以上內容為大家介紹了AngularJs HTTP回應攔截器的相關知識,希望本文分享能為大家帶來幫助。

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1671
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1276
29
C# 教程
1256
24
2022年最新5款的angularjs教學從入門到精通 2022年最新5款的angularjs教學從入門到精通 Jun 15, 2017 pm 05:50 PM

Javascript 是一個非常有個性的語言. 無論是從程式碼的組織, 還是程式碼的程式設計範式, 或物件導向理論都獨具一格. 而很早就在爭論的Javascript 是不是物件導向語言這個問題, 顯然已有答案. 但是, 即使Javascript 叱吒風雲二十年, 如果想要看懂jQuery, Angularjs, 甚至是React 等流行框架, 觀看《黑馬雲課堂JavaScript 高級框架設計視頻教程》就對了。

揭秘 Golang 中的攔截器機制 揭秘 Golang 中的攔截器機制 Apr 08, 2024 am 08:39 AM

攔截器是一種設計模式,允許在方法執行前後插入自訂行為,在Go中可以透過net/http中介軟體實現。它具有可擴展性、可重複使用性、可測試性等優點,可用於身份驗證、授權、快取、日誌記錄和自訂錯誤處理等場景。

使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 使用PHP和AngularJS建立響應式網站,提供優質的使用者體驗 Jun 27, 2023 pm 07:37 PM

在現今資訊時代,網站已成為人們獲取資訊和交流的重要工具。一個響應式的網站能夠適應各種設備,為使用者提供優質的體驗,成為了現代網站開發的熱點。本篇文章將介紹如何使用PHP和AngularJS建立響應式網站,進而提供優質的使用者體驗。 PHP介紹PHP是一種開源的伺服器端程式語言,非常適合Web開發。 PHP具有許多優點,如易於學習、跨平台、豐富的工具庫、開發效

uniapp中路由攔截器的使用技巧 uniapp中路由攔截器的使用技巧 Dec 17, 2023 pm 04:30 PM

uniapp中路由攔截器的使用技巧在uniapp開發中,路由攔截器是一種非常常用的功能。路由攔截器允許我們在路由跳轉前進行一些特定的操作,例如權限驗證、頁面傳遞參數等。在本文中,我們將介紹uniapp中路由攔截器的使用技巧,並提供特定的程式碼範例。建立路由攔截器首先,我們需要在uniapp專案中建立路由攔截器。建立方法如下:在專案根目錄下建立一個inter

全面解析 Golang 中的攔截器 全面解析 Golang 中的攔截器 Apr 07, 2024 am 10:18 AM

在Golang中可以利用攔截器在函數執行前後插入額外程式碼,場景包括日誌記錄、身份驗證、快取等。攔截器的實作方式是建立處理函數類型,然後建立攔截器函數接受處理程序函數並傳回一個新的包含額外邏輯的處理程序函數。在實戰中,我們可以使用攔截器記錄所有請求,方便調試和分析。

了解Spring攔截器的原理與優點 了解Spring攔截器的原理與優點 Dec 30, 2023 pm 12:25 PM

探究Spring攔截器的工作原理及優勢引言:Spring框架是Java開發中最常用的框架之一,它提供了豐富的功能和靈活性,使得開發者能夠更有效率地開發應用程式。其中一個重要的元件就是攔截器(Interceptor)。本文將深入探討Spring攔截器的工作原理和優勢,同時給出具體的程式碼範例。一、Spring攔截器的工作原理Spring攔截器使用了面向切面編程(

在 Golang 中駕馭攔截器 在 Golang 中駕馭攔截器 Apr 07, 2024 pm 09:33 PM

攔截器允許在不修改現有程式碼的情況下,在Go應用程式中插入自訂邏輯。它們可用於身份驗證、日誌記錄、錯誤處理和效能監控等。建立攔截器需要實作Handler接口,它定義了處理HTTP請求的ServeHTTP()和傳遞控制權的Next()方法。實戰案例展示如何使用日誌攔截器記錄所有傳入請求的URL路徑,以及如何將多個攔截器(如身份驗證攔截器)連結在一起以建立複雜的應用程式邏輯。

golang有攔截器嗎 golang有攔截器嗎 Jul 18, 2023 pm 02:23 PM

golang沒有提供內建的攔截器,但可以利用函數、介面和結構體等語言特性來實現類似的功能,以下是常用攔截器實現方式:1、函數式攔截器,透過在請求到達處理程序之前及其之後調用函數來實現攔截器;2、接口式攔截器,透過定義一個接口,並在目標處理程序之前和之後實現該接口來實現攔截器,這種方式可以使攔截器更加靈活,可以在不同的介面上實作不同的攔截器邏輯。

See all articles