我有一个使用jwt身份验证的Angular-springboot程序,我想知道一旦登录角度,如何恢复登录者的数据,例如用户名。我看了一些有关authgaurd和httpinterceptors的指南,但是我对rigurado有点困惑,你们中的任何人都可以给我发一个代码来检索数据吗?我从auth-gaurd,身份验证,basic-auth-http-interceptors和httpclient指南中复制了一些服务,我认为这是非常标准的,但是如果需要,我会发布它们
当用户登录系统时,将令牌类型和jwt令牌保存在本地存储中。在TokenInterceptor的帮助下,它在每个请求中发送标头详细信息。
import { Injectable } from '@angular/core';
import {
HttpRequest,
HttpHandler,
HttpEvent,
HttpInterceptor, HttpResponse
} from '@angular/common/http';
import { Observable } from 'rxjs';
@Injectable()
export class TokenInterceptor implements HttpInterceptor {
constructor() { }
intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
request = request.clone({
setHeaders: {
Authorization: `${localStorage.getItem('token_type')} ${localStorage.getItem('jwt_token')}`
}
});
return next.handle(request);
}
}
在app.module.ts中添加提供者{ provide: HTTP_INTERCEPTORS, useClass: TokenInterceptor, multi: true }