权限认证框架sa-token的token有效期与实时续签

2023-11-30 04:08

本文主要是介绍权限认证框架sa-token的token有效期与实时续签,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

sa-token

sa-token 是一个非常强大的JavaWeb权限认证框架,其集成了诸多好用的特性,诸如:登录验证、权限验证、自定义session会话、踢人下线 等等均可以在框架中一行代码完成调用,官网地址:http://sa-token.dev33.cn/

sa-token的令牌有效期

sa-token 提供两种token自动过期策略,分别是timeoutactivity-timeout,其详细用法如下:

timeout

  • timeout代表token的长久有效期,单位/秒,例如将其配置为2592000(30天),代表在30天后,token必定过期,无法继续使用
  • timeout无法续签,想要继续使用必须重新登录
  • timeout的值配置为-1后,代表永久有效,不会过期

activity-timeout

  • activity-timeout代表临时有效期,单位/秒,例如将其配置为1800(30分钟),代表用户如果30分钟无操作,则此token会立即过期
  • 如果在30分钟内用户有操作,则会再次续签30分钟,用户如果一直操作则会一直续签,直到连续30分钟无操作,token才会过期
  • activity-timeout的值配置为-1后,代表永久有效,不会过期,此时也无需频繁续签

关于activity-timeout的续签

如果activity-timeout配置了大于零的值,sa-token会在登录时开始计时,在每次直接或间接调用getLoginId()时进行一次过期检查与续签操作。
此时会有两种情况:

  • 一种是会话无操作时间太长,token已经过期,此时框架会抛出NotLoginException异常(场景值=-3),
  • 另一种则是会话在activity-timeout有效期内通过检查,此时token可以成功续签

我可以手动续签吗?

可以!
如果框架的自动续签算法无法满足您的业务需求,你可以进行手动续签,sa-token提供两个API供你操作:

  • StpUtil.checkActivityTimeout(): 检查当前token 是否已经[临时过期],如果已经过期则抛出异常
  • StpUtil.updateLastActivityToNow(): 续签当前token:(将 [最后操作时间] 更新为当前时间戳)
  • 注意:在手动续签时,即时token已经 [临时过期] 也可续签成功,如果此场景下需要提示续签失败,可采用先检查再续签的形式保证token有效性
  • 例如以下代码:
	// 先检查是否已过期StpUtil.checkActivityTimeout();// 检查通过后继续续签StpUtil.updateLastActivityToNow();

timeout与activity-timeout可以同时使用吗?

可以同时使用!
两者的认证逻辑彼此独立,互不干扰,可以同时使用。






程序员交流qq群:782974737 点击加入

这篇关于权限认证框架sa-token的token有效期与实时续签的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/435557

相关文章

springboot依靠security实现digest认证的实践

《springboot依靠security实现digest认证的实践》HTTP摘要认证通过加密参数(如nonce、response)验证身份,避免明文传输,但存在密码存储风险,相比基本认证更安全,却因... 目录概述参数Demopom.XML依赖Digest1Application.JavaMyPasswo

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

Linux权限管理与ACL访问控制详解

《Linux权限管理与ACL访问控制详解》Linux权限管理涵盖基本rwx权限(通过chmod设置)、特殊权限(SUID/SGID/StickyBit)及ACL精细授权,由umask决定默认权限,需合... 目录一、基本权限概述1. 基本权限与数字对应关系二、权限管理命令(chmod)1. 字符模式语法2.

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹