Angular中的請(qǐng)求攔截的方法
在上一篇的文章 Angular 中使用 Api 代理,我們處理了本地聯(lián)調(diào)接口的問題,使用了代理。
我們的接口是單獨(dú)編寫的處理的,在實(shí)際的開發(fā)項(xiàng)目中,有眾多的接口,有些需要登陸憑證,有些不需要。一個(gè)一個(gè)接口處理不妥,我們是否可以考慮對(duì)請(qǐng)求進(jìn)行攔截封裝呢?
本文章來實(shí)現(xiàn)下。
區(qū)分環(huán)境
我們需要對(duì)不同環(huán)境下的服務(wù)進(jìn)行攔截。在使用 angular-cli
生成項(xiàng)目的時(shí)候,它已經(jīng)自動(dòng)做好了環(huán)境的區(qū)分,在 app/enviroments
目錄下:
environments ├── environment.prod.ts // 生產(chǎn)環(huán)境使用的配置 └── environment.ts // 開發(fā)環(huán)境使用的配置
我們對(duì)開發(fā)環(huán)境進(jìn)行修改下:
// enviroment.ts export const environment = { baseUrl: '', production: false };
baseUrl
是在你發(fā)出請(qǐng)求的時(shí)候添加在請(qǐng)求的前面的字段,他指向你要請(qǐng)求的地址。我什么都沒加,其實(shí)等同加了 http://localhost:4200
的內(nèi)容。
當(dāng)然,你這里添加的內(nèi)容要配合你代理上加的內(nèi)容調(diào)整,讀者可以自己思考驗(yàn)證
添加攔截器
我們生成服務(wù) http-interceptor.service.ts
攔截器服務(wù),我們希望每個(gè)請(qǐng)求,都經(jīng)過這個(gè)服務(wù)。
// http-interceptor.service.ts import { Injectable } from '@angular/core'; import { HttpEvent, HttpHandler, HttpInterceptor, // 攔截器 HttpRequest, // 請(qǐng)求 } 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) => { // 處理響應(yīng)的數(shù)據(jù) console.log(response) }, (error: any) => { // 處理錯(cuò)誤的數(shù)據(jù) console.log(error) } ) ) } }
要想攔截器生效,我們還得在 app.module.ts
上注入:
// app.module.ts import { HttpClientModule, HTTP_INTERCEPTORS } from '@angular/common/http'; // 攔截器服務(wù) import { HttpInterceptorService } from './services/http-interceptor.service'; providers: [ // 依賴注入 { provide: HTTP_INTERCEPTORS, useClass: HttpInterceptorService, multi: true, } ],
驗(yàn)證
到這里,我們已經(jīng)成功的實(shí)現(xiàn)了攔截器。如果你運(yùn)行 npm run dev
,你會(huì)在控制臺(tái)上看到下面的信息:
想要驗(yàn)證是否需要內(nèi)容憑證才能訪問內(nèi)容,這里我使用了 [post] https://jimmyarea.com/api/private/leave/message
的接口嘗試,得到如下錯(cuò)誤:
后端已經(jīng)處理這個(gè)接口需要憑證才可以進(jìn)行操作,所以直接報(bào)錯(cuò) 401
。
那么,問題來了。我們登陸之后,需要怎么帶上憑證呢?
如下,我們修改下攔截器內(nèi)容:
let secureReq: HttpRequest<any> = req; // ... // 使用 localhost 存儲(chǔ)用戶憑證,在請(qǐng)求頭帶上 if (window.localStorage.getItem('ut')) { let token = window.localStorage.getItem('ut') || '' secureReq = secureReq.clone({ headers: req.headers.set('token', token) }); } // ...
這個(gè)憑證的有效期,需要讀者進(jìn)入系統(tǒng)的時(shí)候,判斷一下有效期是否有效,再考慮重置 localstorage
的值,不然會(huì)一直報(bào)錯(cuò),這個(gè)也是很簡單,對(duì) localstorage
進(jìn)行相關(guān)的封裝方便操作即可~
到此這篇關(guān)于Angular中的請(qǐng)求攔截的方法的文章就介紹到這了,更多相關(guān)Angular 請(qǐng)求攔截內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章

AngularJS $http模塊POST請(qǐng)求實(shí)現(xiàn)

關(guān)于Angularjs中跨域設(shè)置白名單問題

完美解決UI-Grid表格元素中多個(gè)空格顯示為一個(gè)空格的問題

詳解關(guān)于Angular4 ng-zorro使用過程中遇到的問題

詳細(xì)解讀AngularJS中的表單驗(yàn)證編程

Angular引入swiper后autoplay失效的解決辦法詳解

AngularJS實(shí)現(xiàn)根據(jù)變量改變動(dòng)態(tài)加載模板的方法

AngularJS使用angular-formly進(jìn)行表單驗(yàn)證