91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Angular怎么對請求進行攔截封裝

發布時間:2022-04-21 12:05:20 來源:億速云 閱讀:140 作者:iii 欄目:web開發

這篇“Angular怎么對請求進行攔截封裝”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Angular怎么對請求進行攔截封裝”文章吧。

Angular怎么對請求進行攔截封裝

區分環境

我們需要對不同環境下的服務進行攔截。在使用 angular-cli 生成項目的時候,它已經自動做好了環境的區分,在 app/enviroments 目錄下:

environments                                          
├── environment.prod.ts                  // 生產環境使用的配置
└── environment.ts                       // 開發環境使用的配置

我們對開發環境進行修改下:

// enviroment.ts

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

baseUrl 是在你發出請求的時候添加在請求的前面的字段,他指向你要請求的地址。我什么都沒加,其實等同加了 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) => {
          // 處理響應的數據
          console.log(response)
        },
        (error: any) => {
          // 處理錯誤的數據
          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,
  }
],

驗證

到這里,我們已經成功的實現了攔截器。如果你運行 npm run dev,你會在控制臺上看到下面的信息:

Angular怎么對請求進行攔截封裝

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

Angular怎么對請求進行攔截封裝

后端已經處理這個接口需要憑證才可以進行操作,所以直接報錯 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)
  });
}

// ...

這個憑證的有效期,需要讀者進入系統的時候,判斷一下有效期是否有效,再考慮重置 localstorage 的值,不然會一直報錯,這個也是很簡單,對 localstorage 進行相關的封裝方便操作即可。

以上就是關于“Angular怎么對請求進行攔截封裝”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙门县| 连平县| 孟连| 武川县| 久治县| 清远市| 南木林县| 保亭| 横峰县| 河间市| 建平县| 尼玛县| 山东省| 泽普县| 灵宝市| 丹江口市| 锡林浩特市| 西安市| 嘉善县| 巫溪县| 安塞县| 临猗县| 龙南县| 遂溪县| 堆龙德庆县| 石台县| 商城县| 富源县| 峨眉山市| 高雄县| 永德县| 云南省| 益阳市| 潢川县| 张家港市| 河间市| 周至县| 饶河县| 息烽县| 绥棱县| 扶风县|