使用刷新的 JWT 令牌调用 API

Posted

技术标签:

【中文标题】使用刷新的 JWT 令牌调用 API【英文标题】:Calling API with refreshed JWT token 【发布时间】:2018-09-13 07:04:17 【问题描述】:

目前为我的反应应用程序使用 AWS Cognito 开发工具包。 目前,在调用 API 时,我使用 ComponentWillMount 运行会话检查

componentWillMount() 
  if (!this.props.authenticated) 
    this.props.history.push('/auth/login');
   else 
    getUserFromLocalStorage()
      .then(data => 
        console.log('getUserFromLocalStorage');
        this.props.setUserToReduxState(data);

        console.log(
          'user sucess retrieved from local storage and usersettoreduxstate: ',
          data
        )
        .then(console.log('after local test'))
      )

      .catch(() => 
        logoutUserFromReduxState();
      );
  

在 componentDidMount 中,我使用本地存储中的 JWT 令牌调用 API

componentDidMount() 
// calls API with localStage.jwtToken
this.loadData();

这在大多数情况下都有效,但是当令牌过期时,JWT 会被刷新,这一切都会得到处理,但是当最初调用 API 时,它会使用旧的 JWT 调用。我可以看到新的 JWT 在 redux 中被刷新,但它在调用 API 之前被刷新。

是否有任何建议可以确保在进行每次 API 调用之前,令牌在用于 API 调用之前在 redux 中刷新和更新?

【问题讨论】:

【参考方案1】:

这可能是由于 javascript 的异步特性造成的。只需确保 this.lodaData() 等待刷新令牌即可。

例如,componentWillMount 运行身份验证部分,componentDidMount 在进行API 调用之前不会等待身份验证函数完成运行。

现在这无法通过将身份验证部分和 API 分开来完成,但您可以将它们全部放在同一事件中,或者全部放在 componentWillMountcomponentDidMount 中,并确保 API 调用在所有身份验证后被调用。如下所示

refreshToken() 
    return new Promise((resolve, reject) => 
        //refresh token
        resolve()
    )


componentDidMount()
    this.refreshToken().then(() => 
        //API call
    )

【讨论】:

以上是关于使用刷新的 JWT 令牌调用 API的主要内容,如果未能解决你的问题,请参考以下文章

如何在客户端处理多个请求/API 调用并行的 JWT 刷新令牌?

如何在jwt中过期时刷新令牌

如何在 Alamofire Swift 中刷新 JWT 令牌状态代码 500

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

JWT 令牌刷新后返回重新调用

使用过期令牌发出同时 API 请求时如何避免多个令牌刷新请求