我需要对403 Forbidden HTTP状态(获取/刷新)JWT令牌作出反应(在拦截器类中),然后使用新令牌重试该请求。Angular 4.3 - HTTP拦截器 - 刷新JWT令牌
在下面的代码中,当服务器返回错误响应时,它返回到成功回调(而不是像我预期的那样进入错误回调),事件是typeof对象(对错误响应的反应无用)。事件对象如下所示: {type:0}。
问:
- 如何正确处理httpErrorResponse(403禁止)在 HttpInterceptor当我需要刷新的accessToken并重试http请求?
import {
HttpInterceptor,
HttpRequest,
HttpResponse,
HttpHandler,
HttpEvent
} from '@angular/common/http';
import 'rxjs/add/operator/map';
@Injectable()
class JWTInterceptor implements HttpInterceptor {
constructor(private tokenService: TokenService) {}
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
let myHeaders = req.headers;
if (this.tokenService.accessToken) {
myHeaders = myHeaders.append('Authorization',`${this.tokenService.accessToken.token_type} ${this.tokenService.accessToken.access_token}`)
}
const authReq = req.clone({headers: myHeaders});
return next.handle(authReq).map((event: HttpEvent<any>) => {
if (event instanceof HttpResponse) {
// success callback
}
}, (err: any) => {
if (err instanceof HttpErrorResponse {
if (err.status === 403) {
// error callback
this.tokenService.obtainAccessToken()
}
}
})
.retry(1);
}
}
它解决我的问题的一部分 - 在抓我现在可以访问HttpErrorResponse和调用我的刷新/获取令牌逻辑 - 谢谢你。但是当我调用**。retry(1)**时,新的http请求不会再通过拦截器(因此JWT头文件不会添加到新的调用中) – kuceraf
您需要在刷新函数中执行的操作是返回'Observable '。然后在该catch块中返回该刷新函数的调用,并将其添加到拦截器。例如更新答案。 – Lansana