我有一个带jwt认证的Angular-springboot程序,我想知道如何在angular上登录,恢复谁登录的数据,例如用户名。我看了一些authguard和httpinterceptors上的指南,但我对rigurado有点困惑,你们中有谁能给我一个检索数据的代码吗?我有从指南中复制的服务,这些服务是auth-guard、身份验证、basic-auth-http-interceptors和httpclient,我认为它们是相当标准的,但如果需要,我会发布它们。
发布于 2019-11-06 13:38:45
当用户登录系统时,将令牌类型和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中添加provider { provide: HTTP_INTERCEPTORS, useClass: TokenInterceptor, multi: true }
发布于 2019-11-06 17:12:38
谢谢,是的,我有一个像这样的拦截器,它保存在本地存储中,但是如果我在另一个组件中,我想调用它,例如,我按下一个按钮,在我想做的方法中,例如,一个帖子说,如果你按下这个按钮,你必须登录,好吗?,你必须更新数据库,所以我需要知道是谁按下了这个,如何检索这个?
https://stackoverflow.com/questions/58717051
复制相似问题