双token三验证(Refresh Token 机制​)

单token存在的问题

        我们都知道,token是我们在前后端数据传输的时候为了保证安全从而必须需要进行设置的东西,他的主要作用实际上就是为了保证我们的数据安全,进行身份验证和授权,并且相对于session而言更加适合如今的分布式系统,但是,token本身是无状态的,无法动态设置能不能使用,也就是说任何人获得了当前的token就能够利用token进行网络攻击,例如多台ip设备并发攻击当前网站等,下面列出传统的解决方案

解决

给token设置一个过期时间,例如jwt生成的token实际上是可以设置时间的,当时间过期之后当前token就无法进行使用了,可以有效的避免因泄露造成的安全,但是,这样就会出现一个问题,时间应当设置多少,如果设置的比较短,用户会频繁的登录,如果设置的比较长,会不太安全,为了解决这个问题,我们采取【双token三验证】的解决方案来解决这个问题

方案原理

token有效期长不安全

        登录成功之后,生成两个token,分别是access_token,和refresh_token,前者有效期可以较短,后者有效期可以较长

        正常请求后端服务的时候,携带access_token,如果发现access_token失效,就通过refresh_token到后台去获取新的access_token和refresh_token,你可以理解为token的续表,

        以此往复,直到refresh_token过期重新登录即可

token的无状态性

        为了使token有状态,也就是我们可以控制token的什么时候失效,我们可以将refresh_token设置为只能够使用一次

        那么这个时候就需要将refresh_token存储到redis中,并且设置过期时间

        当我们检测到token异常的时候,就可以直接令refresh_token失效即可

具体流程

1.前端将用户名和密码给予我们的时候,我们判断是否合理,然后生成access_token以及refresh_token即可

2.refresh_token和access_token可以都是jwt生成,但是,要注意,access_token的时间要短一下,refresh_token的时间要长一下,并且,refresh_token的有效时间并非是由jwt控制的,而是我们的redis存入的时候进行控制的,这也是为了使得token具有有效性,

3.将a_token和r_token返回前端即可

4.当登录成功之后再次发出请求,这一次可以仅仅返回access_token也就是那个时间比较短的token,然后我们进行校验,如果当前的access_token合理,返回响应结果即可,也就是第一次验证

5.如果access_token不合理,那我们返回401,让前端返回refresh_token,我们检验这个token是否有效,无效返回重新登录,有效继续,也就是第二次验证

6.我们查询redis中当前的refresh_token,看看是否存在和使用过,如是是,返回错误,不是的话就去删除旧的token生成新的access_token和refresh_token

7.循环往复

这样就解决了token的无状态性带来的问题。/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/85028.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/85028.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

青少年编程与数学 01-011 系统软件简介 22 VMware 虚拟化软件

青少年编程与数学 01-011 系统软件简介 22 VMware 虚拟化软件 一、历史沿革(一)创立阶段(1998-2003)(二)快速扩张(2004-2010)(三)云时代转型(2011…

FPGA基础 -- Verilog门级建模之奇偶校验电路

✅ 一、什么是奇偶校验(Parity Check) 📌 定义: 奇偶校验是一种错误检测编码方式,用于判断一个二进制数据在传输或存储过程中是否发生了单比特错误。 奇校验(Odd Parity):总共有奇…

UWB协议精读:IEEE 802.15.4z-2020,15. HRP UWB PHY, STS, HRP-ERDEV, BPRF, HPRF,

跟UWB相关的IEEE标准主要有2个: 1,IEEE 802.15.4-2020 2,IEEE 802.15.4z-2020 IEEE Std 802.15.4z™ ‐ 2020 Amendment 1: Enhanced Ultra Wideband (UWB) Physical Layers (PHYs) and Associated Ranging Techniques scrambled timestamp sequence (STS): A sequence of…

6.IK分词器拓展词库

比如一些行业专业词汇、简单无意义词(例如:的、得、地、是等)、网络流行词、后来形成的词、再或者一些禁忌词(比如:领导人的名字、黄赌毒犯罪等词要排除的) 在es的插件目录下查找配置文件: 找到IKAnalyzer…

Web3-Web3.js核心操作:Metamask、合约调用、事件订阅全指南

Web3-Web3.js核心操作:Metamask、合约调用、事件订阅全指南 我们做了Solidity的合约代码,但是合约仅仅是一个后端逻辑;我们想要让用户来操作你的逻辑还需要做一个基本的网页。如果要做一个基本的网页,我们就要使用到以太坊基金发布…

四色(定理/猜想)染色算法小软件Version1.11

四色(定理/猜想)染色算法小软件Version1.11 2025.6.16 开发者:路人甲/打酱油 增加了【自思肯普法】 为什么加上【自思】两字?因为我也看不明英文的PDF的四色定理证明文档,分什么成千上百种类来证明。我就是百度下,看相关介绍&am…

【Linux驱动开发 ---- 2_深入理解内核模块】

Linux驱动开发 ---- 2_深入理解内核模块 目录 Linux驱动开发 ---- 2_深入理解内核模块学习目标时间安排建议 理论学习1. 什么是内核模块?2. 模块加载与卸载3. 内核模块开发基础 实践任务任务1:准备开发环境任务2:编写简单内核模块任务3&#…

Linux SUID提权 案例以及知识点提高分析

目录 📚 Linux SUID 提权原理与红队实践 🚀 概述 🛠️ SUID 提权原理 核心机制 技术栈 🔍 案例背景:sudo -l 与 .monit 脚本 案例信息 脚本内容 🧪 提权步骤分解 📋 1. 检查 sudo 权限…

S参数与串扰-信号完整性分析

S参数与串扰: 四端口网络S参数中,仍表示反射,表示信号的传输。根据S参数的定义,和两个参数的含义为 当只有端口1有正弦信号激励源时,从端口3和端口4出来的正弦信号只能是互连结构内部耦合过来的,因此表示的是近端串扰…

Android OkHttp 框架超时设置详解

OkHttp 提供了四种不同的超时设置,每种针对网络请求的不同阶段: 1. callTimeout (调用超时) 作用:控制整个调用从开始到结束的总时间,包括所有重定向和重试 默认值:0 (不超时) 场景:当你希望限制整个请求…

如何让LLM通过反思来提升生成sql的正确率 - 以Gemini生成sql为例

什么是Agent Reflection 通常指 “智能体反思”,即让 AI 系统通过自我反思机制优化决策或任务处理过程,类似人类通过复盘改进策略。 创建一个 SQL Agent 导入相关的库 import openai import pandas as pd import sqlite3 from util.get_schema impor…

数字IC学习笔记(二)

数字IC学习笔记(二) 宏定义,异步FIFO, 时钟来源,复位信号 文章目录 数字IC学习笔记(二)1. define宏定义的使用2,异步FIFO原理3,时钟来源4,复位参考资料 1. define宏定义的…

日志输出功能

当程序运行出现问题时,日志记录是一种非常有用的工具,它可以帮助我们追踪和定位问题。在 MicroPython 中,可以使用 log 模块来记录程序运行中的信息。本文将介绍 log 模块的使用方法和常见功能。 日志级别 log.DEBUG 常量,用来…

【JVM】- 类加载与字节码结构1

类文件结构 ClassFile {u4 magic;u2 minor_version;u2 major_version;u2 constant_pool_count;cp_info constant_pool[constant_pool_count-1];u2 access_flags;u2 this_class;u2 …

Android及Harmonyos实现图片进度显示效果

鸿蒙Harmonyos实现,使用ImageKnife自定义transform来实现图片进度效果 import { Context } from ohos.abilityAccessCtrl; import { image } from kit.ImageKit; import { drawing } from kit.ArkGraphics2D; import { GrayScaleTransformation, PixelMapTransform…

linux 中的自动化之systemd

linux | 自动化之systemd linux 中的自动化之systemd 学习总是循序渐进的。 linux 中程序的自动化,包括早期手动启动,查看启动后的日志、分析启动情况,再到后面封装脚本(大致要求启动后检查是否挂了,挂了拉起,没挂跳过…

【编译工具】CodeRider 2.0:驭码 CodeRider 2.0 全流程智能研发协作平台深度技术测评报告

目录 前言:CodeRider 2.0 简介 (1)核心功能 (2)适用场景 (3)优势 一、产品概述与技术架构 (1)产品定位与核心价值 (2)技术架构解析 &…

抓包 TCP 四次挥手报文

文章目录 抓包 TCP 三次握手报文一、第一次挥手二、第二次挥手三、第三次挥手四、第四次挥手 抓包 TCP 三次握手报文 抓包 TCP 三次握手报文 一、第一次挥手 二、第二次挥手 三、第三次挥手 四、第四次挥手

KMP(Kotlin Multiplatform)发布Web版本乱码

一、背景 最近用KMP尝试运行在Android、iOS、desktop都成功了,网络数据访问也正常。 可是当运行wasmJs的时候遇到了2个较大的问题。 中文字体出现乱码。 出现了跨域问题。 首先贴一下每个平台的运行截图: Android iOS Desktop 二、问题 当web跑起…

一个应用程序或移动网站项目提供最佳UI解决方案

一个应用程序或移动网站项目提供最佳UI解决方案 此套件是用大量的爱和辛勤工作制作的,为您的下一个应用程序或移动网站项目提供最佳解决方案。120个完全可编辑的界面,分为10个类别和2种文件格式,Photoshop和AI。简单易用的结构将允许您以所…