Angular如何从authgaurd检索?

问题描述 投票:0回答:1

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

angular post angular-http-interceptors jwt-auth auth-guard
1个回答
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 }

© www.soinside.com 2019 - 2024. All rights reserved.