当前位置:首页 > 文章列表 > 文章 > 前端 > JWT过期时间设置与验证技巧

JWT过期时间设置与验证技巧

2025-11-26 13:00:33 0浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《JWT过期时间设置与验证问题解析》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

Node.js中JWT过期时间设置与验证:解决

本文深入探讨在Node.js应用中使用jsonwebtoken库设置JWT过期时间时可能遇到的“7天”设置不生效的问题。文章通过分析常见代码实现,强调了expiresIn参数的正确用法,并提供了详细的验证方法,特别是如何利用jwt.io等工具检查JWT负载中的exp(过期时间)声明,以确保令牌按预期工作,并区分了JWT过期与Cookie生命周期。

1. JWT过期时间设置概述

JSON Web Token (JWT) 广泛应用于认证和授权场景。在Node.js环境中,jsonwebtoken库是生成和验证JWT的常用工具。设置JWT的过期时间是其核心功能之一,通常通过sign方法的expiresIn选项来指定。这个选项接受多种格式,包括数字(秒)或字符串(如"1h", "7d")。

一个常见的需求是根据用户选择(例如“记住我”功能)来动态调整JWT的有效期。例如,如果用户选择“不登出”,则令牌有效期为7天;否则为7小时。

以下是一个典型的generateAuthToken函数实现,用于根据doNotLogout参数生成具有不同过期时间的JWT:

const jwt = require("jsonwebtoken");

/**
 * 生成认证JWT令牌
 * @param {string} _id - 用户ID
 * @param {string} name - 用户名
 * @param {string} lastName - 用户姓氏
 * @param {string} email - 用户邮箱
 * @param {boolean} isAdmin - 是否是管理员
 * @param {boolean} doNotLogout - 是否延长登录时间(7天)
 * @returns {string} 生成的JWT令牌
 */
const generateAuthToken = (_id, name, lastName, email, isAdmin, doNotLogout) => {
  // 根据doNotLogout参数设置过期时间
  const expiresIn = doNotLogout ? "7d" : "7h";
  return jwt.sign(
    { _id, name, lastName, email, isAdmin },
    process.env.JWT_SECRET_KEY, // 从环境变量获取密钥
    { expiresIn: expiresIn } // 设置令牌过期时间
  );
};

module.exports = { generateAuthToken };

在实际应用中,这个函数会被集成到用户登录流程中,如下所示:

// ... 其他导入和设置

const loginUser = async (req, res, next) => {
  try {
    const { email, password, doNotLogout } = req.body;
    // ... 用户验证逻辑

    if (user && comparePasswords(password, user.password)) {
      let cookieParams = {
        httpOnly: true,
        secure: process.env.NODE_ENV === "production",
        sameSite: "strict",
      };

      // 如果doNotLogout为真,则设置Cookie的maxAge为7天
      if (doNotLogout) {
        cookieParams = { ...cookieParams, maxAge: 1000 * 60 * 60 * 24 * 7 };
      }

      return res
        .cookie(
          "access_token",
          // 调用generateAuthToken生成JWT
          generateAuthToken(
            user._id,
            user.firstname,
            user.lastName,
            user.email,
            user.isAdmin,
            // 确保这里传入的是从请求体获取的doNotLogout,而不是user对象上的属性
            doNotLogout
          ),
          cookieParams
        )
        .status(200)
        .json({
          _id: user._id,
          name: user.firstname,
          lastName: user.lastName,
          email: user.email,
          isAdmin: user.isAdmin,
          doNotLogout,
        });
    } else {
      res.status(401).json({ error: "Wrong Credentials" });
    }
  } catch (err) {
    next(err);
  }
};

重要提示: 在loginUser函数中调用generateAuthToken时,传递doNotLogout参数时应使用从req.body获取的值,即doNotLogout,而不是user.doNotLogout,以确保用户请求的过期行为被正确应用。原始代码中此处可能存在一个潜在的逻辑错误。

2. 常见问题:JWT过期时间未按预期生效

开发者在使用上述代码时,可能会遇到一个困惑:即使doNotLogout设置为true,期望令牌有效期为7天,但实际上令牌似乎在7小时后就失效了。这通常导致认证失败,即使Cookie仍然存在于浏览器中。

当确认expiresIn变量的值(例如"7d")在generateAuthToken函数内部是正确设置的,但问题依然存在时,我们需要将注意力转向JWT本身的结构和验证。

3. JWT过期时间验证方法

jsonwebtoken库在内部会根据expiresIn选项计算出一个Unix时间戳,并将其作为exp(expiration time)声明添加到JWT的负载(payload)中。当验证JWT时,库会检查当前的Unix时间戳是否超过了exp的值。

解决“过期时间不生效”问题的关键在于直接检查生成的JWT负载中的exp声明

3.1 使用在线工具验证JWT

最直接和推荐的方法是使用在线JWT调试工具,例如 jwt.io

验证步骤:

  1. 获取生成的JWT令牌:
    • 在您的应用程序中,当generateAuthToken函数返回令牌后,将其打印到控制台,或者通过浏览器开发者工具从HTTP响应的Cookie中复制access_token的值。
  2. 访问jwt.io:
  3. 粘贴令牌:
    • 将复制的JWT令牌粘贴到jwt.io页面左侧的“Encoded”文本区域。
  4. 检查负载(Payload):
    • jwt.io会自动解码令牌,并在中间的“Payload”部分显示其内容。查找名为exp的声明。
    • exp的值是一个Unix时间戳(自1970年1月1日00:00:00 UTC以来经过的秒数)。jwt.io通常会将其转换为可读的日期和时间格式,方便您验证。

示例分析:

如果doNotLogout为true,且expiresIn被设置为"7d",那么exp的值应该表示当前时间加上7天后的Unix时间戳。如果exp显示的是当前时间加上7小时后的时间,那么问题可能出在generateAuthToken函数中expiresIn变量的实际值,或者jsonwebtoken库的版本兼容性问题(尽管这不太常见)。

通过这种方式,您可以直观地确认JWT内部存储的过期时间是否与您的预期一致。如果exp值正确,那么问题可能不在JWT本身,而是在于您的应用程序如何处理或验证这个令牌。

3.2 区分JWT过期与Cookie maxAge

在上述loginUser函数中,我们不仅设置了JWT的过期时间,还为存储JWT的Cookie设置了maxAge。理解这两者的区别至关重要:

  • JWT exp (expiration time): 这是JWT内部的一个声明,由签发者定义,表示令牌何时失效。服务器在收到令牌后,会验证这个exp声明。即使Cookie仍然存在,如果JWT已过期,服务器也会拒绝该令牌。
  • Cookie maxAge / Expires: 这是HTTP Cookie的一个属性,由浏览器管理。它指示浏览器何时删除该Cookie。

如果Cookie的maxAge设置得比JWT的exp短,那么在JWT过期之前,Cookie就可能已经被浏览器删除了,导致用户会话提前结束。反之,如果Cookie的maxAge设置得比JWT的exp长,那么即使Cookie仍然存在,但由于JWT已经过期,用户也无法通过认证。

在示例代码中,当doNotLogout为true时,cookieParams.maxAge被设置为1000 * 60 * 60 * 24 * 7,这与JWT的"7d"过期时间是匹配的。确保这两者逻辑上保持一致是最佳实践。

4. 总结与注意事项

  1. 验证exp声明是关键: 当遇到JWT过期时间不符合预期的问题时,第一步且最重要的一步是使用jwt.io等工具检查生成的JWT的exp负载声明。这能帮助您快速定位问题是出在令牌生成环节,还是令牌消费/验证环节。
  2. jsonwebtoken库的可靠性: jsonwebtoken库对于expiresIn参数的处理通常是可靠的。如果exp值不正确,首先检查generateAuthToken函数中expiresIn变量的实际值是否正确传递。
  3. doNotLogout参数的传递: 确保在调用generateAuthToken时,doNotLogout参数的值是用户期望的(例如从请求体中获取),而不是意外地使用了默认值或错误的值。
  4. 版本兼容性: 虽然不常见,但如果所有其他检查都无法解决问题,可以考虑检查jsonwebtoken库和Node.js的版本,并查阅其官方文档是否有已知问题或更新。
  5. 服务端与客户端过期处理: 明确区分JWT的exp(服务端验证)和Cookie的maxAge(客户端/浏览器管理)。两者应协同工作,以提供一致的用户体验。

通过遵循这些步骤和注意事项,您将能够有效地诊断并解决Node.js应用程序中JWT过期时间设置不生效的问题。

今天关于《JWT过期时间设置与验证技巧》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

ES6合并对象的常用方法有哪些ES6合并对象的常用方法有哪些
上一篇
ES6合并对象的常用方法有哪些
《猿编程》证书查询方法详解
下一篇
《猿编程》证书查询方法详解
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    3167次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    3380次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    3409次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    4513次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    3789次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码