首页 > web前端 > js教程 > 正文

如何校验JWT Access Token的有效性

聖光之護
发布: 2025-09-18 17:12:13
原创
163人浏览过

如何校验jwt access token的有效性

本文旨在提供一个清晰、健壮的方法来校验JSON Web Token (JWT) Access Token的有效性。我们将讨论如何检查token是否存在于本地存储、是否为undefined、格式是否正确以及是否已过期。通过提供的代码示例和解释,你将能够更好地处理各种token状态,确保你的应用程序安全可靠。

JWT Access Token 有效性校验详解

在使用基于JWT(JSON Web Token)的认证方案时,前端通常会将Access Token存储在本地存储(localStorage)中。在应用程序的生命周期内,我们需要定期或在特定操作前校验token的有效性,以确保用户身份的正确性。以下将详细介绍如何进行校验,并提供相应的代码示例。

1. 检查 Access Token 是否存在

首先,我们需要检查access_token是否存在于localStorage中。localStorage.getItem('access_token') 方法会返回以下两种情况:

  • 如果access_token存在,则返回其对应的值。
  • 如果access_token不存在,则返回 null。

因此,我们可以直接判断localStorage.getItem('access_token')的返回值是否为 null 来确定 token 是否存在。

2. 检查 Access Token 是否为 "undefined" 字符串

需要注意的是,如果开发者手动将access_token的值设置为undefined(字符串),localStorage.getItem('access_token') 将返回字符串 "undefined",而不是 JavaScript 中的 undefined 类型。因此,我们需要额外判断返回值是否为字符串 "undefined"。

有道小P
有道小P

有道小P,新一代AI全科学习助手,在学习中遇到任何问题都可以问我。

有道小P 64
查看详情 有道小P

3. 检查 Access Token 格式是否正确

在确认 token 存在后,我们需要验证其格式是否正确。JWT 具有特定的格式(由三部分组成,分别是 Header、Payload 和 Signature,并用点号 . 分隔)。如果 token 的格式不正确,尝试解析它将会抛出异常。因此,我们需要使用 try...catch 块来捕获解析 token 时可能发生的错误。

4. 检查 Access Token 是否已过期

JWT 的 Payload 部分通常包含 exp (expiration time) 声明,表示 token 的过期时间,以 Unix 时间戳表示。我们需要将当前时间与 exp 的值进行比较,判断 token 是否已过期。

代码示例

以下是一个完整的代码示例,演示了如何校验 Access Token 的有效性:

function isAccessTokenValid() {
  let accessToken = localStorage.getItem('access_token');
  let isValid = false;

  if (accessToken === null || accessToken === 'undefined') {
    // Token 不存在或值为 "undefined"
    isValid = false;
  } else {
    try {
      // 尝试解析 token
      const decodedToken = parseJwt(accessToken);

      // 检查 token 是否已过期
      if (Date.now() >= decodedToken.exp * 1000) {
        // Token 已过期
        isValid = false;
      } else {
        // Token 有效
        isValid = true;
      }
    } catch (error) {
      // Token 格式不正确
      isValid = false;
    }
  }

  return isValid;
}

// 解析 JWT Token 的函数 (需要根据实际情况实现)
function parseJwt(token) {
  try {
    const base64Url = token.split('.')[1];
    const base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');
    const jsonPayload = decodeURIComponent(atob(base64).split('').map(function(c) {
        return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
    }).join(''));

    return JSON.parse(jsonPayload);
  } catch (error) {
    // 处理解析错误,例如 token 格式不正确
    console.error("Error parsing JWT:", error);
    throw error; // 重新抛出异常,让外层 try...catch 捕获
  }
}


// 使用示例
if (isAccessTokenValid()) {
  console.log("Access Token is valid.");
  // 执行需要授权的操作
} else {
  console.log("Access Token is invalid.");
  // 提示用户重新登录或刷新 token
}
登录后复制

注意事项

  • 安全性: 永远不要信任客户端的 token 校验结果。服务器端必须进行相同的校验,以确保安全性。
  • parseJwt 函数: 代码示例中的 parseJwt 函数用于解析 JWT token。你需要根据你的实际需求实现这个函数。有很多现成的库可以用来解析 JWT,例如 jsonwebtoken。
  • 错误处理: 在 try...catch 块中,务必处理解析 token 时可能发生的错误。这有助于防止应用程序崩溃,并提供更好的用户体验。
  • Token 刷新: 如果 token 已过期,你应该提示用户重新登录或使用 Refresh Token 刷新 Access Token。

总结

校验 JWT Access Token 的有效性是确保应用程序安全性的重要步骤。通过检查 token 是否存在、格式是否正确以及是否已过期,我们可以有效地防止未经授权的访问。 结合上述代码示例和注意事项,你将能够更好地处理 JWT Access Token,并构建更安全可靠的应用程序。

以上就是如何校验JWT Access Token的有效性的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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