0

0

Django Simple JWT 刷新令牌轮换与页面刷新策略

花韻仙語

花韻仙語

发布时间:2025-11-10 11:47:01

|

1019人浏览过

|

来源于php中文网

原创

django simple jwt 刷新令牌轮换与页面刷新策略

在使用Django Simple JWT并启用刷新令牌轮换(`ROTATE_REFRESH_TOKENS`)时,快速页面刷新可能导致令牌在接收新令牌前被黑名单。本文将深入探讨此问题,并提供一种更健壮的解决方案:通过利用现有访问令牌处理页面加载,并在访问令牌过期时采用同步刷新机制,从而避免不必要的刷新令牌轮换,确保用户体验和系统安全。

理解刷新令牌轮换的挑战

当Django Simple JWT的ROTATE_REFRESH_TOKENS和BLACKLIST_AFTER_ROTATION设置同时启用时,每次使用刷新令牌获取新的访问令牌时,都会生成一个新的刷新令牌,并且旧的刷新令牌会被立即列入黑名单。这种机制增强了安全性,因为即使旧的刷新令牌被泄露,其有效期也极短。

然而,在前端(例如使用React.js)实现持久化登录,并允许用户在短时间内频繁刷新页面时,可能会出现一个竞态条件:

  1. 用户刷新页面,前端尝试使用(或可能无意中触发)刷新令牌来获取新的访问令牌。
  2. 后端生成新的访问令牌和刷新令牌,并将旧的刷新令牌列入黑名单。
  3. 在前端成功接收并存储新的刷新令牌之前,用户再次刷新页面。
  4. 第二次页面刷新时,前端可能仍然持有已被列入黑名单的旧刷新令牌,导致认证失败。

这种场景下,用户可能会频繁遇到需要重新登录的问题,严重影响用户体验。

核心原则:页面加载不应触发令牌刷新

解决上述问题的关键在于理解令牌的用途和生命周期:

  • 访问令牌 (Access Token):用于授权访问受保护的资源。它通常具有较短的有效期。
  • 刷新令牌 (Refresh Token):用于在访问令牌过期后,安全地获取新的访问令牌。它通常具有较长的有效期。

一个基本的原则是:页面刷新本身不应该触发刷新令牌的轮换。 当用户刷新页面时,后端应该直接接收并使用HTTP-only Cookie中现有的访问令牌来验证用户身份并提供数据。只有当这个访问令牌过期时,才需要考虑使用刷新令牌。

健壮的令牌刷新策略

为了确保应用的可靠性和用户体验,推荐采用以下策略来处理令牌的生命周期和刷新:

1. 依赖现有访问令牌处理页面加载

当用户刷新页面或导航到其他页面时,前端应确保将现有的访问令牌(通过HTTP-only Cookie自动发送)发送给后端。后端接收到请求后,会尝试使用此访问令牌进行认证。

Flowith
Flowith

一款GPT4驱动的节点式 AI 创作工具

下载
  • 如果访问令牌有效:后端正常处理请求并返回数据。
  • 如果访问令牌过期:后端应返回一个 401 Unauthorized 响应。这是前端启动令牌刷新流程的明确信号。

2. 实施同步刷新令牌机制

当前端收到 401 Unauthorized 响应时,它需要执行一次刷新令牌操作来获取新的访问令牌。为了避免在并发请求场景下(例如,页面上有多个组件同时请求数据,且访问令牌同时过期)出现多个刷新令牌请求,导致竞态条件,建议实现同步刷新机制:

  • 单一刷新请求:确保在任何给定时间点,只有一个刷新令牌的请求在进行中。
  • 请求队列:当第一个刷新请求正在进行时,所有后续的(因 401 响应而触发的)API请求都应该被暂停并放入一个队列中。
  • 刷新成功后重试:一旦刷新令牌请求成功,获取到新的访问令牌,队列中的所有API请求都应使用新的访问令牌进行重试。
  • 刷新失败处理:如果刷新令牌请求失败(例如,刷新令牌也已过期),则所有队列中的请求都应失败,并且用户需要被重定向到登录页面。

这种同步刷新机制能够可靠地处理多个并发视图同时获取数据的情况,避免了不必要的刷新令牌轮换和潜在的黑名单问题。

3. 处理刷新令牌过期

最终,刷新令牌本身也会过期。当后端尝试使用一个过期的刷新令牌来生成新的访问令牌时,OAuth 2.0 规范通常会返回一个 invalid_grant 错误码。

  • 前端处理:当前端收到 invalid_grant 错误时,这意味着用户的会话已完全过期,需要用户重新进行身份验证。此时,前端应将用户重定向到登录页面。

对比用户提出的解决方案

用户提出的手动黑名单方案:

@api_view(['POST'])
def blacklist_token(request):
    refreshToken = request.data.get("refresh")
    print(refreshToken)
    if refreshToken:
        token = tokens.RefreshToken(refreshToken)
        token.blacklist()
    return Response(status=status.HTTP_200_OK)

这个方案试图让前端在收到新的刷新令牌后,主动发送请求将旧的刷新令牌列入黑名单。虽然这听起来可以解决竞态问题,但它引入了额外的复杂性,并且与Simple JWT的BLACKLIST_AFTER_ROTATION设置功能重叠。更重要的是,它并没有从根本上解决“页面刷新不应该触发令牌刷新”的核心问题。如果每次页面刷新都尝试进行令牌刷新和手动黑名单操作,仍然可能在网络延迟或用户操作过快时导致问题。

推荐的做法是让Simple JWT的自动轮换和黑名单机制正常工作,并将重点放在前端如何智能地处理访问令牌过期,而不是在每次页面刷新时都尝试进行刷新令牌操作。

最佳实践与注意事项

  1. 充分测试过期事件:务必在开发和测试阶段模拟访问令牌和刷新令牌的过期事件。这包括:
    • 访问令牌过期后,前端能否成功刷新并重试请求。
    • 刷新令牌过期后,前端能否正确引导用户重新登录。
    • 在并发请求和快速页面刷新场景下,验证同步刷新机制的健壮性。
  2. HTTP-only Cookies:确保将访问令牌和刷新令牌都存储在HTTP-only Cookies中。这能有效防止XSS攻击窃取令牌。
  3. 前端状态管理:前端需要有清晰的状态管理来追踪令牌的有效性、刷新请求的状态以及需要重试的请求队列。
  4. 用户体验:在令牌刷新或过期时,向用户提供明确的反馈(例如,加载指示器、会话过期提示),以避免困惑。

总结

在使用Django Simple JWT实现认证并启用刷新令牌轮换时,解决快速页面刷新导致的问题,关键在于改变对页面加载的认知。页面刷新应依赖现有的访问令牌。只有当访问令牌过期时,才应通过一个健壮的、同步的机制来使用刷新令牌获取新的访问令牌。同时,妥善处理刷新令牌的最终过期,引导用户重新认证。通过遵循这些原则和最佳实践,可以构建一个既安全又用户友好的认证系统。

相关专题

更多
cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6409

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

338

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

401

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6049

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

784

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1052

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1100

2024.03.01

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.2万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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