news 2026/1/31 18:11:36

安全的 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/1/23 15:49:04

从传感器到图表:PHP实现农业数据实时可视化的5个关键步骤

第一章:从传感器到图表的农业数据可视化概述现代农业正逐步迈向数字化与智能化,其中数据可视化在农业生产决策中扮演着关键角色。通过部署环境传感器采集温度、湿度、土壤水分等关键参数,原始数据被转化为直观的图表,帮助农户实时…

作者头像 李华
网站建设 2026/1/27 22:58:34

业务导向型技术日志首日记录(业务中使用的技术栈)

每做完一个项目我都会小做总结后端技术栈总结,以下是项目中使用的所有后端技术及其业务应用情况: xx管理系统后端技术栈总结 1. 核心框架与语言 Java 基础使用:面向对象编程语言,平台无关性,支持多线程、异常处理、…

作者头像 李华
网站建设 2026/1/23 15:42:29

基于SpringBoot + Vue的宠物殡葬网站设计

文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言 💛博主介绍&#…

作者头像 李华
网站建设 2026/1/31 3:06:16

基于Uniapp + SpringBoot + Vue的中医个性化养生系统的设计与实现

文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言 💛博主介绍&#…

作者头像 李华
网站建设 2026/1/24 10:31:32

亲测有效:打印机驱动程序无法使用的完整解决思路

在日常办公、学习甚至家庭使用中,打印机几乎属于“刚需设备”。可偏偏很多人都遇到过这样一个让人抓狂的提示——打印机驱动程序无法使用。 打印任务发不出去,扫描功能点了没反应,设备管理器里一切看似正常,但就是用不了。更气人…

作者头像 李华
网站建设 2026/1/30 6:07:48

ollama pull qwen:32b命令执行失败原因排查

ollama pull qwen:32b 命令执行失败原因排查与深度解析 在当前大语言模型(LLM)快速演进的背景下,越来越多企业和开发者开始尝试将高性能模型部署到本地环境,以满足数据隐私、响应速度和定制化能力的需求。Ollama 作为一款专为本地…

作者头像 李华