javascript - 使用此 JWT 库检查 token 是否已过期

标签 javascript node.js express jwt

我已经像这样配置了 token :

jwt.sign(
  {
    user: pick(user, ['_id', 'username'])
  },
  secret,
  {
    expiresIn: '2m'
  }
);

但是当我想检查 token 是否过期时,这段代码不起作用:

function isAuthenticated() {
  const token = localStorage.getItem('token');
  const refreshToken = localStorage.getItem('refreshToken');
  try {
    decode(token);
    const { exp } = decode(refreshToken);
    if (exp < (new Date().getTime() + 1) / 1000) {
      return false;
    }
  } catch (err) {
    return false;
  }
  return true;
}

问题出在这部分:

if (exp < (new Date().getTime() + 1) / 1000) {
  return false;
}

new Date().getTime() + 1)/1000 = 1531335468.113

exp = 1531334595

因为我不知道 JWT 使用什么格式的时间...

我该如何解决这个问题?

最佳答案

这就是答案:

if (Date.now() >= exp * 1000) {
  return false;
}

关于javascript - 使用此 JWT 库检查 token 是否已过期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51292406/

相关文章:

node.js - Amazon Rekognition 图像 : error InvalidImageFormatException: Request has invalid image format

javascript - 打印所有已安装的 node.js 模块的列表

javascript - Nodejs 和快速路由,如何处理客户端 promise

javascript - 通过ajax将字符串发送到运行express.js的Node.js服务器无法正常工作

javascript - 使用 Express 路由 React 服务器端

javascript - 将表单输入与 JSON 对象进行比较

javascript - 如何使用 node.js 在 html 中调用外部 javascript 文件

javascript - 如何将 lodash 更新到最新版本

javascript - 处理从 PHP 页面返回的 MYSQL 查询结果

javascript - 检查未定义会导致未定义错误