日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

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 對請求進行攔截封裝
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定