新标题:计算并更新令牌的剩余过期时间
P粉463840170
P粉463840170 2023-08-26 23:13:42
[React讨论组]

我需要在React应用程序中每隔一个小时刷新Spotify令牌(Spotify令牌有效期为1小时)。我知道以下方法使用useEffect钩子和setInteral

useEffect(() => {
  const interval = setInterval(() => {
    //调用API逻辑
  }, 3600);
  return () => clearInterval(interval); 
}, [user])

但是当应用程序关闭并重新打开时,它会再次发出新的请求以获取令牌(即使旧令牌仍然有效)。因此,我正在尝试根据剩余到期时间来实现需要调用API以获取新令牌的功能。如何实现这个功能。

我还创建了一个函数,用于在过去的时间之后计算剩余到期时间

export const calculateRemainingExpirationTime = expirationTime => {
  const currentTime = new Date().getTime();
  const newExpirationTime = new Date(expirationTime).getTime()
  const remainingTime = newExpirationTime - currentTime
  return remainingTime; //以毫秒为单位
};

因此,当页面重新加载时,我需要计算剩余到期时间,然后基于该时间调用API,然后每隔1小时调用API以获取新令牌。

我需要实现以下功能

  1. 当页面重新加载时,计算剩余时间并根据剩余时间调用API
  2. 每隔1小时调用API


P粉463840170
P粉463840170

全部回复(1)
P粉805535434

你需要将过期时间持久化到localStorage或使用Redux-persist来保存

//此间隔仅在用户未关闭应用程序时执行
useEffect(() => {
  const interval = setInterval(() => {
    //调用api逻辑
    //将过期时间写入本地存储
     localStorage.setItem("expir",value)
  }, 3600);
  return () => clearInterval(interval); 
}, [user])
//获取在本地存储中写入/存储的过期时间

 React.useEffect(() => {
    let mounted = true;
    const getToken = () => {
      if (mounted) {
        const expirationtime = localStorage.getItem("expir");
        if (new Date() > new Date(Number(expirationtime))) {
          // 过期,获取新的令牌
        } else {
          // 存在的令牌
        }
      }
    };
    getToken();
    return () => {
      mounted = false;
    };
  }, [user]);
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号