Angular中的請求攔截的方法
在上一篇的文章 Angular 中使用 Api 代理,我們處理了本地聯(lián)調接口的問題,使用了代理。
我們的接口是單獨編寫的處理的,在實際的開發(fā)項目中,有眾多的接口,有些需要登陸憑證,有些不需要。一個一個接口處理不妥,我們是否可以考慮對請求進行攔截封裝呢?
本文章來實現(xiàn)下。
區(qū)分環(huán)境
我們需要對不同環(huán)境下的服務進行攔截。在使用 angular-cli 生成項目的時候,它已經自動做好了環(huán)境的區(qū)分,在 app/enviroments 目錄下:
environments ├── environment.prod.ts // 生產環(huán)境使用的配置 └── environment.ts // 開發(fā)環(huán)境使用的配置
我們對開發(fā)環(huán)境進行修改下:
// enviroment.ts
export const environment = {
baseUrl: '',
production: false
};baseUrl 是在你發(fā)出請求的時候添加在請求的前面的字段,他指向你要請求的地址。我什么都沒加,其實等同加了 http://localhost:4200 的內容。
當然,你這里添加的內容要配合你代理上加的內容調整,讀者可以自己思考驗證
添加攔截器
我們生成服務 http-interceptor.service.ts 攔截器服務,我們希望每個請求,都經過這個服務。
// http-interceptor.service.ts
import { Injectable } from '@angular/core';
import {
HttpEvent,
HttpHandler,
HttpInterceptor, // 攔截器
HttpRequest, // 請求
} from '@angular/common/http';
import { Observable } from 'rxjs';
import { tap } from 'rxjs/operators';
import { environment } from 'src/environments/environment';
@Injectable({
providedIn: 'root'
})
export class HttpInterceptorService implements HttpInterceptor {
constructor() { }
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
let secureReq: HttpRequest<any> = req;
secureReq = secureReq.clone({
url: environment.baseUrl + req.url
});
return next.handle(secureReq).pipe(
tap(
(response: any) => {
// 處理響應的數(shù)據
console.log(response)
},
(error: any) => {
// 處理錯誤的數(shù)據
console.log(error)
}
)
)
}
}要想攔截器生效,我們還得在 app.module.ts 上注入:
// app.module.ts
import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http';
// 攔截器服務
import { HttpInterceptorService } from './services/http-interceptor.service';
providers: [
// 依賴注入
{
provide: HTTP_INTERCEPTORS,
useClass: HttpInterceptorService,
multi: true,
}
],驗證
到這里,我們已經成功的實現(xiàn)了攔截器。如果你運行 npm run dev,你會在控制臺上看到下面的信息:

想要驗證是否需要內容憑證才能訪問內容,這里我使用了 [post] https://jimmyarea.com/api/private/leave/message 的接口嘗試,得到如下錯誤:

后端已經處理這個接口需要憑證才可以進行操作,所以直接報錯 401。
那么,問題來了。我們登陸之后,需要怎么帶上憑證呢?
如下,我們修改下攔截器內容:
let secureReq: HttpRequest<any> = req;
// ...
// 使用 localhost 存儲用戶憑證,在請求頭帶上
if (window.localStorage.getItem('ut')) {
let token = window.localStorage.getItem('ut') || ''
secureReq = secureReq.clone({
headers: req.headers.set('token', token)
});
}
// ...這個憑證的有效期,需要讀者進入系統(tǒng)的時候,判斷一下有效期是否有效,再考慮重置 localstorage 的值,不然會一直報錯,這個也是很簡單,對 localstorage 進行相關的封裝方便操作即可~
到此這篇關于Angular中的請求攔截的方法的文章就介紹到這了,更多相關Angular 請求攔截內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
AngularJS $http模塊POST請求實現(xiàn)
本篇文章主要介紹了AngularJS $http模塊POST請求實現(xiàn),這里整理了詳細的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
完美解決UI-Grid表格元素中多個空格顯示為一個空格的問題
下面小編就為大家?guī)硪黄昝澜鉀QUI-Grid表格元素中多個空格顯示為一個空格的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
詳解關于Angular4 ng-zorro使用過程中遇到的問題
這篇文章主要介紹了詳解關于Angular4 ng-zorro使用過程中遇到的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
Angular引入swiper后autoplay失效的解決辦法詳解
這篇文章主要介紹了Angular引入swiper后autoplay失效的解決辦法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09
AngularJS實現(xiàn)根據變量改變動態(tài)加載模板的方法
這篇文章主要介紹了AngularJS實現(xiàn)根據變量改變動態(tài)加載模板的方法,結合實例形式簡單分析了AngularJS動態(tài)加載模板的主要操作技巧與模板實現(xiàn)代碼,需要的朋友可以參考下2016-11-11
AngularJS使用angular-formly進行表單驗證
這篇文章主要介紹了AngularJS使用angular-formly進行表單驗證的相關資料,需要的朋友可以參考下2015-12-12

