我有一个带有 jwt 身份验证的 Angular-springboot 程序,我想知道如何在 Angular 上登录后,恢复登录者的数据,例如用户名。我查看了一些关于 authguard 和 httpinterceptors 的指南,但我对 rigurado 有点困惑,你们中的任何人都可以给我发一个它检索数据的代码吗?我有从指南中复制的服务,这些服务是 auth-guard、authentication、basic-auth-http-interceptors 和 httpclient 我认为是非常标准的,但如果需要我会发布它们
问问题
149 次
2 回答
0
当用户登录系统时,将令牌类型和 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 }
于 2019-11-06T05:38:45.283 回答
0
谢谢,是的,我有一个这样的拦截器,它保存在本地存储中,但是如果我在另一个组件中,并且我想调用它,例如我按下一个按钮,并且在我想做的方法中,例如,一个帖子如果你按下这个按钮,你必须登录好吗?你必须更新数据库,所以我需要知道谁按下了这个,如何找回这个?
于 2019-11-06T09:12:38.010 回答