news 2026/5/26 7:58:05

安全的 Token 刷新机制:Refresh Token 轮换与权限实时同步

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
安全的 Token 刷新机制:Refresh Token 轮换与权限实时同步

安全的 Token 刷新机制:Refresh Token 轮换与权限实时同步

在现代 Web 应用中,基于 JWT 的无状态认证广泛使用。然而,为了兼顾安全性和用户体验,通常采用双 Token 机制(Access Token + Refresh Token)。本文将详细阐述如何安全地实现 Refresh Token 的存储、轮换,并确保权限变更能实时生效。

一、核心原则

  • Refresh Token 以 SessionId 为唯一标识:每个会话对应一个 Refresh Token
  • Refresh Token 可重复使用:在有效期内可多次刷新 Access Token
  • Access Token 必须反映用户当前状态:刷新时应重新加载用户最新角色和权限
  • Refresh Token 应持久化存储:因其低频使用,适合存入数据库

二、Refresh Token 数据库表设计

由于 Refresh Token 使用频率低,将其存储在关系型数据库中是安全且高效的选择。以下是推荐的表结构:

CREATETABLErefresh_tokens(idBIGINTPRIMARYKEYAUTO_INCREMENT,session_idVARCHAR(128)NOTNULLUNIQUECOMMENT'会话唯一标识',user_idVARCHAR(64)NOTNULL,token_hashVARCHAR(255)NOTNULLCOMMENT'Refresh Token 的 BCrypt 哈希值',device_infoVARCHAR(500)COMMENT'设备或浏览器信息',login_channelVARCHAR(50)COMMENT'登录渠道:web/app/wechat等',ip_addressVARCHAR(45),created_atDATETIMENOTNULLDEFAULTCURRENT_TIMESTAMP,expires_atDATETIMENOTNULL,revokedBOOLEANDEFAULTFALSECOMMENT'是否已被撤销',last_used_atDATETIME,use_countINTDEFAULT0COMMENT'使用次数统计',INDEXidx_user_id(user_id),INDEXidx_session_id(session_id),INDEXidx_token_hash(token_hash),INDEXidx_expires_at(expires_at));

字段说明:

  • session_id:会话唯一标识,用于管理特定设备/浏览器的登录状态
  • login_channel:区分登录来源(Web端、App、小程序等)
  • use_count:统计 Refresh Token 被使用的次数

三、完整实现流程

1. 用户登录

  • 验证用户名/密码
  • 生成唯一session_id(UUID)
  • 生成 Access Token(含当前角色)和 Refresh Token
  • 将 Refresh Token 信息存入refresh_tokens
  • 返回 Token 对和session_id给客户端

2. 刷新 Access Token(关键步骤)

  1. 客户端发送session_id+ Refresh Token 到/auth/refresh
  2. 服务端根据session_id查询对应的 Refresh Token 记录
  3. 验证 Refresh Token 是否有效(未过期、未撤销、哈希匹配)
  4. 重新从用户服务加载用户最新信息(包括角色、启用状态等)
  5. 若用户已被禁用或删除,拒绝刷新
  6. 生成新的 Access Token(基于最新权限)
  7. 使用原有 Refresh Token(不重新生成)
  8. 更新使用次数和最后使用时间
  9. 返回新 Access Token 给客户端

3. 用户登出

  • 客户端调用/auth/logout并传入session_id
  • 服务端根据session_id将对应 Refresh Token 标记为已撤销

四、时序图:完整的 Token 刷新流程

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/25 20:41:25

5个关键R包搞定甲基化数据分析,生物信息新手也能快速上手

第一章:甲基化数据分析入门与R语言环境搭建 DNA甲基化是表观遗传学中的核心机制之一,通过在胞嘧啶上添加甲基基团影响基因表达而不改变DNA序列。随着高通量测序技术的发展,全基因组甲基化分析(如WGBS、RRBS)已成为研究…

作者头像 李华
网站建设 2026/5/26 6:01:29

UDP网络巩固知识基础题(5)

1. UDP协议在物联网(IoT)应用中的优势和实现要点? 答案: UDP在IoT环境中具有天然优势: 主要优势: 资源消耗低: 协议简单,内存和CPU占用少 功耗低: 无连接维护,减少无线电活动时间 实时性好: 适合传感器数据的及时上报 开销小: 适合传输小量数据 实现要点: 协议设…

作者头像 李华
网站建设 2026/5/26 4:55:18

Laravel 13多模态验证规则深度解析(前所未见的灵活验证方案)

第一章:Laravel 13多模态验证规则概述Laravel 13 引入了多模态验证规则系统,显著增强了表单请求和数据校验的灵活性与表达能力。该机制允许开发者在一个验证规则中组合多种条件模式,如基于请求方法、输入来源或上下文环境动态切换验证逻辑&am…

作者头像 李华
网站建设 2026/5/26 4:53:23

多模态缓存清理全解析,Laravel 13开发者必须掌握的3种高阶技巧

第一章:多模态缓存清理的核心概念与Laravel 13演进在现代Web应用开发中,缓存机制已成为提升系统性能的关键手段。随着Laravel 13的发布,框架对多模态缓存管理进行了深度优化,支持同时操作多种缓存后端(如Redis、Memcac…

作者头像 李华
网站建设 2026/5/26 4:50:50

6G真的要来了?中国移动这次把“未来网络”摆到了台前

很多人对6G的印象,可能还停留在“5G都没用明白,6G是不是太早了”。但在12月中旬的中国信息通信大会上,中国移动把答案摆得很直白——不是概念图,也不是口号,而是一份白皮书,加上一台已经能跑起来的原型样机…

作者头像 李华
网站建设 2026/5/25 15:20:57

黄金成色怎么看?新手第一次买金,别只盯着“亮不亮”

第一次买黄金的人,十有八九都会被一个问题绊住:这金子,到底纯不纯?我身边就有朋友,拿着一条“看起来很黄”的项链反复端详,最后还是不放心地问柜员一句:“这是足金吗?”其实&#xf…

作者头像 李华