亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 HTTP 攔截器成功刷新令牌并執行請求后重試組件中的訂閱

在 HTTP 攔截器成功刷新令牌并執行請求后重試組件中的訂閱

冉冉說 2023-03-18 11:25:12
我需要幫助來弄清楚如何在我的攔截器刷新令牌并成功克隆并再次發出 http 請求后重試組件中出現錯誤 401 的訂閱。在我收到錯誤 401 后,我的攔截器獲取新令牌并調用任何端點。我正在取回數據,但問題出在我的組件中,錯誤卡在那里,沒有任何反應,如果我刷新視圖,一切都恢復正常,但我想知道如何刷新或重試該組件訂閱以繼續401錯誤消失后的過程。這是我在攔截器中的 401 處理:intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {    return from(this.db.storage.get(TOKEN_KEY))    .pipe(      switchMap((token: any) => {      if (token) {      request = this.addToken(request, token.token);      }      return next.handle(request).pipe(catchError(error => {        if (!window.navigator.onLine) {          this.ui.showSwalErrorPrompt('Error','No internet conection!.');          return //cancel request      }else{        if (error instanceof HttpErrorResponse && error.status === 401) {          this.handle401Error(request, next,token);       } else if(error instanceof HttpErrorResponse && error.status === 500){         return throwError(error);       }else if(error instanceof HttpErrorResponse && error.status === 0){        return throwError(error);       }      }      return throwError(error);    }));  })    );  }  private addToken(request: HttpRequest<any>, token: string) {    return request.clone({      setHeaders: {        Authorization: `Bearer ${token}`      }    });  }  private handle401Error(request: HttpRequest<any>, next: HttpHandler,tokens) {    if (!this.isRefreshing) {      this.isRefreshing = true;      this.refreshTokenSubject.next(null);      return this.auth.refreshToken(tokens).pipe(        switchMap((token: any) => {          this.isRefreshing = false;          this.refreshTokenSubject.next(token.token);          this.db.removeAll('token');          this.db.storage.set('token',token);          return next.handle(this.addToken(request, token.token));        }));    } else {      return this.refreshTokenSubject.pipe(        filter(token => token != null),        take(1),        switchMap(jwt => {          return next.handle(this.addToken(request, jwt));        }));    }  }
查看完整描述

1 回答

?
溫溫醬

TA貢獻1752條經驗 獲得超4個贊

只需在返回處理技巧之前添加返回即可。如果不返回,邏輯就不起作用。

if (error instanceof HttpErrorResponse && error.status === 401) { 
         return this.handle401Error(request, next,token);


查看完整回答
反對 回復 2023-03-18
  • 1 回答
  • 0 關注
  • 105 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號