1

我有一个带有 jwt 身份验证的 Angular-springboot 程序,我想知道如何在 Angular 上登录后,恢复登录者的数据,例如用户名。我查看了一些关于 authguard 和 httpinterceptors 的指南,但我对 rigurado 有点困惑,你们中的任何人都可以给我发一个它检索数据的代码吗?我有从指南中复制的服务,这些服务是 auth-guard、authentication、basic-auth-http-interceptors 和 httpclient 我认为是非常标准的,但如果需要我会发布它们

4

2 回答 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 回答