在我的 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
,<router-outlet>
将呈现一些其他组件,并且RecentComponent
将触发对myapi.com/getRecentPhotos
的 HTTP 请求,这需要id_token
。在这种情况下,我该如何修改此代码?抱歉,我已经为此苦苦挣扎了一段时间,所以我想知道是否有更好的方法。
在首先加载的父组件中运行 get token onInit .....因为每个服务都从 localStorage 获取它,所以我没有看到问题。
是的,但是我的app.component
正在渲染router-outlet
(可能会渲染一些像RecentComponent 这样的组件,也可能会渲染<navigation-top></navigation-top>
。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 中刷新令牌?