亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Angular中的請求攔截的方法

 更新時間:2022年04月06日 09:29:21   作者:Jimmy  
我們的接口是單獨(dú)編寫的處理的,在實(shí)際的開發(fā)項(xiàng)目中,有眾多的接口,有些需要登陸憑證,有些不需要。一個一個接口處理不妥,我們是否可以考慮對請求進(jìn)行攔截封裝,感興趣的可以了解一下

在上一篇的文章 Angular 中使用 Api 代理,我們處理了本地聯(lián)調(diào)接口的問題,使用了代理。

我們的接口是單獨(dú)編寫的處理的,在實(shí)際的開發(fā)項(xiàng)目中,有眾多的接口,有些需要登陸憑證,有些不需要。一個一個接口處理不妥,我們是否可以考慮對請求進(jìn)行攔截封裝呢?

本文章來實(shí)現(xiàn)下。

區(qū)分環(huán)境

我們需要對不同環(huán)境下的服務(wù)進(jìn)行攔截。在使用 angular-cli 生成項(xiàng)目的時候,它已經(jīng)自動做好了環(huán)境的區(qū)分,在 app/enviroments 目錄下:

environments                                          
├── environment.prod.ts                  // 生產(chǎn)環(huán)境使用的配置
└── environment.ts                       // 開發(fā)環(huán)境使用的配置

我們對開發(fā)環(huán)境進(jìn)行修改下:

// enviroment.ts

export const environment = {
  baseUrl: '',
  production: false
};

baseUrl 是在你發(fā)出請求的時候添加在請求的前面的字段,他指向你要請求的地址。我什么都沒加,其實(shí)等同加了 http://localhost:4200 的內(nèi)容。

當(dāng)然,你這里添加的內(nèi)容要配合你代理上加的內(nèi)容調(diào)整,讀者可以自己思考驗(yàn)證

添加攔截器

我們生成服務(wù) http-interceptor.service.ts 攔截器服務(wù),我們希望每個請求,都經(jīng)過這個服務(wù)。

// 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) => {
          // 處理響應(yīng)的數(shù)據(jù)
          console.log(response)
        },
        (error: any) => {
          // 處理錯誤的數(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,你會在控制臺上看到下面的信息:

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

后端已經(jīng)處理這個接口需要憑證才可以進(jìn)行操作,所以直接報(bào)錯 401。

那么,問題來了。我們登陸之后,需要怎么帶上憑證呢?

如下,我們修改下攔截器內(nèi)容:

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)
  });
}

// ...

這個憑證的有效期,需要讀者進(jìn)入系統(tǒng)的時候,判斷一下有效期是否有效,再考慮重置 localstorage 的值,不然會一直報(bào)錯,這個也是很簡單,對 localstorage 進(jìn)行相關(guān)的封裝方便操作即可~

到此這篇關(guān)于Angular中的請求攔截的方法的文章就介紹到這了,更多相關(guān)Angular 請求攔截內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

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

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

    本篇文章主要介紹了AngularJS $http模塊POST請求實(shí)現(xiàn),這里整理了詳細(xì)的代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • AngularJs 指令詳解及示例代碼

    AngularJs 指令詳解及示例代碼

    本文主要介紹AngularJs 指令的知識,這里整理了詳細(xì)的資料和簡單示例代碼幫助大家學(xué)習(xí)理解應(yīng)用,有興趣的小伙伴可以參考下
    2016-09-09
  • 關(guān)于Angularjs中跨域設(shè)置白名單問題

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

    這篇文章主要介紹了Angularjs中關(guān)于跨域設(shè)置白名單問題,需要的朋友可以參考下
    2018-04-04
  • 完美解決UI-Grid表格元素中多個空格顯示為一個空格的問題

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

    下面小編就為大家?guī)硪黄昝澜鉀QUI-Grid表格元素中多個空格顯示為一個空格的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 詳解關(guān)于Angular4 ng-zorro使用過程中遇到的問題

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

    這篇文章主要介紹了詳解關(guān)于Angular4 ng-zorro使用過程中遇到的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • 詳細(xì)解讀AngularJS中的表單驗(yàn)證編程

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

    這篇文章主要介紹了詳細(xì)解讀AngularJS中的表單驗(yàn)證編程,AngularJS是一個非常熱門的JavaScript庫,需要的朋友可以參考下
    2015-06-06
  • Angular引入swiper后autoplay失效的解決辦法詳解

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

    這篇文章主要介紹了Angular引入swiper后autoplay失效的解決辦法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • AngularJS實(shí)現(xiàn)根據(jù)變量改變動態(tài)加載模板的方法

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

    這篇文章主要介紹了AngularJS實(shí)現(xiàn)根據(jù)變量改變動態(tài)加載模板的方法,結(jié)合實(shí)例形式簡單分析了AngularJS動態(tài)加載模板的主要操作技巧與模板實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2016-11-11
  • AngularJS使用angular-formly進(jìn)行表單驗(yàn)證

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

    這篇文章主要介紹了AngularJS使用angular-formly進(jìn)行表單驗(yàn)證的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • 最新評論