双token认证的实现流程图
创作时间:
作者:
@小白创作中心
双token认证的实现流程图
引用
CSDN
1.
https://blog.csdn.net/chaijingqi/article/details/137779038
单token机制
认证机制
单token认证机制在项目中仅使用一个Access Token的访问令牌进行用户身份认证和授权的方案处理。
实现步骤
- 发送验证码:用户提交手机号码后,后端生成一个随机的验证码,并将其与用户手机号码关联。然后,后端将验证码使用JWT编码,并将其发送到用户的手机。
- 验证验证码:用户输入收到的验证码后,前端将其发送到后端。后端验证该验证码是否有效,并返回一个包含用户信息的JWT令牌。
- 登录:前端将JWT令牌存储在本地,并在后续的请求中将其发送到后端作为身份验证的凭据。
不足之处
- 令牌过期问题:单一令牌机制可能存在过期问题。如果令牌的有效期太长,可能会增加安全风险;而如果有效期太短,用户可能需要频繁地重新登录。解决方法可以是使用短期令牌,并结合刷新令牌机制来延长会话时间。
- 令牌泄露风险:一旦令牌泄露,黑客可以使用该令牌冒充用户进行操作。为了减少泄露风险,可以采用HTTPS传输协议,并在令牌中包含较少敏感信息,以及采用其他安全机制如IP限制或设备识别等。
- 单点故障:如果使用单一令牌机制,一旦令牌被篡改或失效,用户可能需要重新登录所有相关的服务。使用分布式令牌管理系统或者采用多因素身份验证可以降低这种风险。
- 跨设备登录问题:如果用户在多个设备上登录,可能需要频繁刷新或重新获取令牌。这可能会增加用户体验的复杂性。可以考虑使用多设备登录管理机制或长期持久化令牌来解决这个问题。
- 权限控制不灵活:单一令牌机制可能无法灵活地控制不同用户或不同角色的权限。在这种情况下,可以结合使用令牌和访问控制列表(ACL)等机制来实现更灵活的权限管理。
安全性较低(因为只有一个token在客户端和服务器端之间进行传递,一旦Access Token被截获或者被泄露,攻击者就会在有效时间内完成模拟用户行为,访问所有受保护资源)
短有效期策略限制无法撤销会话(为了提高安全性access token通常设置的时间是比较短的,然而需要频繁的去获取access token,影响的是用户的体验,尤其是长时间操作或者是后台的服务场景下就会遇到一个瓶矜,而且也无法撤销对应的汇报,如果某个token被盗用了,难以立即撤销这个token的有效性,从而不能立即中断攻击者的访问权限)
无代态刷新问题(若要自动去刷新token维持长期的绘画,单token的机制需要将刷新的逻辑耦合到具体的业务流程当中,这就会增加复杂性和潜在的安全风险)
没有权限细分管理(单一的access token包含所有的授权信息,不易于对不同范文或者是力度的一个资源进行精细化的访问控制)
双Token机制
操作机制
双Token主要包含了AccessToken (访问令牌) 和 RefreshToken (刷新令牌),它的出现就是为了解决单token的不足,所以才会引入双token的机制也就是 RefreshToken (刷新令牌),因为它可以延长实际的绘画时间,用户提供了一种安全的方式来去更新AccessToken,并且在必要的时候撤销特定用户的权限,而并不会影响有效的绘画内容。
实际上双token的机制是 o os 2.0标准中常见的一种实现,主要包含两个类型的token,一个是AccessToken (访问令牌) ,一个是RefreshToken (刷新令牌)
- AccessToken (访问令牌):它会设置一个有效时间较短的令牌内容,用于的是用户每次请求受保护资源时,进行身份验证的操作,通常直接包含在api请求头或者是URL地址参数之中,用于证明客户端其实是有权限去访问特定的资源的
- RefreshToken (刷新令牌):刷新令牌,会设置一个有效时间比较长并且安全存储比较高的一个令牌,主要用于AccessToken过期了以后,去重新获取AccessToken的操作内容。我们并不需要用户去提供一个特殊的登录凭证。因为RefreshToken 一般不会频繁的在网络上进行传输,目的就是为了降低被截取的一个风险
双token的优势
- 安全性提升:因为AccessToken和RefreshToken其实是会被分离的,即使AccessToken被盗用了,但是由于有效时间是比较短的,损失还是可以控制的,同时RefreshToken的安全性则会变的更高,一般还不暴露在网络的传输过程当中,攻击者其实很难窃取到AccessToken长期的有效访问权限
- 用户体验优化:RefreshToken可以实现无感知的token刷新,也就是我们所说的无感刷新,因为当AccessToken失效的时候,客户端就会自动去刷新AccessToken,利用的就是RefreshToken,用户并不需要进行一个重新的登录,从而保证操作的连贯性
- 权限控制灵活:而且双token机制还有很好的权限控制灵活性,可以通过控制RefreshToken的有效期,刷新次数等方式来灵活的管理用户的绘画生命周期,并且在必要的时候去撤销RefreshToken的内容从而终止后续所以AccessToken的一个访问生成
双token的实现流程图
热门推荐
南京博物院:中华文明瑰宝深度游
探秘南京:大报恩寺与云锦博物馆的文化盛宴
南京林业大学树木标本馆:20万份标本见证百年树人
企业拜年祝福语:如何用温暖的话语凝聚人心?
老板拜年祝福语:领导给你最牛的祝福!
肺癌靶向药副作用管理秘籍大揭秘!
黄芪党参助你轻松应对肺癌靶向药副作用
林根医生教你应对ALK阳性肺癌靶向药副作用
贵安算力助力《哪吒2》:当1.3亿亿次/秒算力遇上动画巨制
冯巩:30年春晚,一部中国喜剧史
备战冬运会:短跑运动员的科学营养补充方案
备战巴黎奥运!本杰明·戈登揭秘短跑运动员饮食秘籍
元旦禁放烟花,空气质量真的变好了吗?
如何写出温馨真诚的生日贺卡,让祝福更加难忘与特别
郴州探秘:云海雾凇与丹霞秘境之旅
凉拌鱼皮的正宗做法与家庭温馨回忆
五年磨一剑:《郴州通典》背后的编纂故事
郴州经济增速领跑湖南,招商引资成果显著
西江千户苗寨:打卡特色吊脚楼
冬日打卡:西江千户苗寨深度游全攻略
西江千户苗寨:如何拍出朋友圈爆赞大片?
百慕大三角最新揭秘:美军方公布惊人真相!
百慕大三角:历史谜团与科学解释
揭秘百慕大三角:空气炸弹和龙卷风的真相
从零花钱到理财观:如何培养孩子的财商?
从一场生日会引发的思考:如何培养孩子的精明消费观?
个人养老金税收优惠落地,你准备好了吗?
个人养老金税收优惠全解读:从开户到领取
专家解读:普洱茶真的能防癌吗?
普洱茶对肺癌患者真的有帮助吗?