mirror of
https://gitee.com/dromara/sa-token.git
synced 2025-04-05 17:37:53 +08:00
1.6 KiB
1.6 KiB
持久层扩展
- 每次重启项目都需要重新登录一次,我想把会话数据都放在
Redis
、MongoDB
等专业的缓存中间件中,这样重启项目也不用重新登录,行不行?行! - sa-token 在架构设计时将数据持久操作全部抽象到接口
SaTokenDao
中,此设计可以保证开发者对数据持久层的灵活扩展 - 除了框架内部对
SaTokenDao
提供的基于内存的默认实现,官方仓库还提供了以下扩展方案:
1. sa-token 整合 Redis (使用jdk默认序列化方式)
<!-- sa-token整合redis (使用jdk默认序列化方式) -->
<dependency>
<groupId>cn.dev33</groupId>
<artifactId>sa-token-dao-redis</artifactId>
<version>1.12.1</version>
</dependency>
优点:兼容性好,缺点:Session序列化后基本不可读,对开发者来讲等同于乱码
2. sa-token 整合 Redis (使用jackson序列化方式)
<!-- sa-token整合redis (使用jackson序列化方式) -->
<dependency>
<groupId>cn.dev33</groupId>
<artifactId>sa-token-dao-redis-jackson</artifactId>
<version>1.12.1</version>
</dependency>
优点:Session序列化后可读性强,可灵活手动修改,缺点:兼容性稍差
请注意,无论使用哪种序列化方式,你都必须为项目提供一个Redis实例化方案,例如:
<!-- 提供redis连接池 -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
</dependency>
更多框架的集成方案正在更新中... (欢迎大家提交pr)