在我的 Angular 2 应用程序中使用 JWT 并将其存储在 localStorage 中。但是,当该项目不存在时,我该如何处理?

Posted

技术标签:

【中文标题】在我的 Angular 2 应用程序中使用 JWT 并将其存储在 localStorage 中。但是,当该项目不存在时,我该如何处理?【英文标题】:Using JWT in my angular 2 application and storing it in localStorage. However, how do I handle for when that item doesn't exist? 【发布时间】:2017-05-06 05:35:09 【问题描述】:

我创建了一个token-service.ts,它调用我的后端身份验证 API,该 API 返回一个 JWT。我将此 JWT 存储在本地存储中,如我的getToken() 中所示:

getToken() 
  this.http.post('myAuthEndpoint',  credentials )
  .subscribe((res) => 
    const token = res.headers.get('Authorization')
    localStorage.setItem('id_token', token);
  );

在我的app.component.ts 中,我在ngOnInit 方法中调用getToken()

但是,这是我在app.component.html 中的内容:

<navigation-top></navigation-top>
<router-outlet></router-outlet>

这就是我遇到问题的地方——在我的NavigationTop 组件中,我从top-navigation.service.ts 调用我的getNavigationTop() 来填充链接和内容。我在 getNavigationTop() 中进行的 API 调用需要我在 getToken() 中获得的身份验证令牌,但它在初始化时为空。

我该如何处理这种情况?现在,当我在第一次加载后重新加载页面时它可以工作,因为我可以从 localStorage 获取值:

getNavigationTop(): Observable<any> 
  let headers = new Headers( 'Authorization': localStorage.getItem('token') );
  let options = new RequestOptions( headers: headers );
  let data = this.http
    .get('my url', options)
    .map((res: Response) => 
      return res.json().navTop;
    )
    .catch(this.handleError);
  return data;

谢谢

【问题讨论】:

【参考方案1】:

将它们移动到服务中,并将其作为提供者添加到您的主模块中。

然后在下面执行此操作。然后,您可以将服务注入任何组件并随意调用它们。

@Injectable()
export class TokenService 
    getToken() 
      this.http.post('myAuthEndpoint',  credentials )
      .subscribe((res) => 
        const token = res.headers.get('Authorization')
        localStorage.setItem('id_token', token);
        this.getNavigationTop(token);
      );
    


    getNavigationTop(token?): Observable<any> 
      let headers = new Headers( 'Authorization': token ? token: localStorage.getItem('token') );

然后在组件中:

import TokenService from '..../';

...



    @Component
export class NavigationTop 

    constructor(private tokenService: TokenService) 
      

    ngOnInit() 

    this.tokenService.getToken();
    

现在,如果您稍后再次运行 getNavigationTop,它将首先检查令牌参数(可选),但如果不存在,请尝试使用 localstorage。

【讨论】:

谢谢。这里唯一的问题是我有大约十几个服务将使用id_token。在那种情况下我将如何处理?因此,如果我点击了mysite.com/recent&lt;router-outlet&gt; 将呈现一些其他组件,并且RecentComponent 将触发对myapi.com/getRecentPhotos 的 HTTP 请求,这需要id_token。在这种情况下,我该如何修改此代码?抱歉,我已经为此苦苦挣扎了一段时间,所以我想知道是否有更好的方法。 在首先加载的父组件中运行 get token onInit .....因为每个服务都从 localStorage 获取它,所以我没有看到问题。 是的,但是我的app.component 正在渲染router-outlet(可能会渲染一些像RecentComponent 这样的组件,也可能会渲染&lt;navigation-top&gt;&lt;/navigation-top&gt;。NavigationTop 是一个标题,它使用我的一些链接进行了更新API。但是,在我的app.component.ts onInit 中,我正在调用 getToken(),但同时我的 NavigationTop 的 onInit 正在调用 getNavigationTop()。但是,该调用将没有 id_token,因为 getToken() 没有还没完呢。

以上是关于在我的 Angular 2 应用程序中使用 JWT 并将其存储在 localStorage 中。但是,当该项目不存在时,我该如何处理?的主要内容,如果未能解决你的问题,请参考以下文章

使用 Angular 发送到 Aspnet core 1.0 网站的 JWT

没有 AuthHttp 的提供者!在 angular2-jwt 上

通过 Angular 4 将 JWT 令牌附加到 api 请求

如何使用 jwt 在 Angular 6 和 web api 中刷新令牌?

nodejs 和 Angular 应用程序使用 JWT 发送 401 Unauthorized 和 200 OK

JWT 刷新令牌 Angular