由于提供新的刷新令牌后访问令牌已过期,因此重新发起失败的请求

时间:2020-03-06 10:46:25

标签: angular authentication refresh angular8 interceptor

当令牌过期时出现错误时,我会发送新访问令牌的请求。我成功获取新的access_token,但无法再次重新发送以前的失败请求。

import { Injectable } from '@angular/core';
import { HttpRequest, HttpHandler, HttpEvent, HttpInterceptor, HttpClient } from '@angular/common/http';
import { Observable, throwError } from 'rxjs';
import { catchError } from 'rxjs/operators';
import { AuthenticationService } from './authentication.service';
import { environment } from 'src/environments/environment';


@Injectable({
  providedIn: 'root'
})
export class ErrorInterceptorService implements HttpInterceptor {

  constructor(private authenticationService: AuthenticationService, public http: HttpClient,
) { }

    intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
        return next.handle(request).pipe(catchError(err => {
          console.log("error interceptor" , err);
            if (err.error.http_status === 403) {
                console.log("status code");
                    this.authenticationService.getAccessToken();

            }

            const error = err.error.message || err.statusText;
            return throwError(error);
        }))
    }
}

身份验证服务

这是我的身份验证服务获取访问令牌方法

getAccessToken(){
    let token = JSON.parse(localStorage.getItem('currentUser'));
    console.log("refreshToken" ,token.refresh_token);
    this.currentUserSubject.next(token.refresh_token);
    let reqHead = new HttpHeaders({
      Authorization: `Bearer ${token.refresh_token}`,
      'x-api-key': environment.XAPIKEY,
      'app_id': environment.AUTHAPIKEY
    });

    return this.http.get(environment.AUTHAPI + '/auth/token' ,{ headers: reqHead}).subscribe(
      (data: any) => {
        console.log("data" ,data);
        //If reload successful update tokens
          //Update tokens

          localStorage.removeItem('currentUser');
           data.refresh_token = token.refresh_token 
          localStorage.setItem("currentUser", JSON.stringify(data));
          this.currentUserSubject.next(data);
          //Clone our fieled request ant try to resend its

      }
    );

  }

0 个答案:

没有答案