Sa-Token的基本用法

Sa-Token 是一个轻量级的 Java 权限认证框架,专为简化权限管理和用户认证而设计。它支持多种认证方式(如登录认证、权限认证、角色认证等),并且可以与 Spring Boot、Spring MVC 等框架无缝集成。Sa-Token 的设计理念是简单易用,适合快速开发中小型项目。

以下是 Sa-Token 的核心功能和使用示例:


Sa-Token 的核心功能

  1. 登录认证

    • 提供简单的登录、注销接口。

    • 支持多端登录(如 Web、APP、小程序等)。

  2. 权限认证

    • 基于注解或代码的方式实现权限校验。

    • 支持细粒度的权限控制。

  3. 角色认证

    • 支持用户角色的校验和管理。

  4. 会话管理

    • 提供会话管理功能,支持分布式会话。

  5. 踢人下线

    • 支持强制用户下线。

  6. 注解式开发

    • 提供 @SaCheckLogin@SaCheckRole@SaCheckPermission 等注解,简化权限校验。

  7. 集成简单

    • 支持与 Spring Boot、Spring MVC 等框架无缝集成。


Sa-Token 的快速入门

1. 添加依赖

在 pom.xml 中添加 Sa-Token 的依赖:

<dependency>
    <groupId>cn.dev33</groupId>
    <artifactId>sa-token-spring-boot-starter</artifactId>
    <version>1.34.0</version> <!-- 请使用最新版本 -->
</dependency>

2. 配置 Sa-Token

在 application.yml 中配置 Sa-Token:

sa-token:
  token-name: satoken  # Token 名称
  timeout: 1800        # Token 有效期,单位:秒
  activity-timeout: -1 # Token 临时有效期(-1 表示永久有效)
  is-share: true       # 是否共享 Cookie
  is-read-body: true   # 是否从请求体中读取 Token

3. 实现登录功能

在控制器中实现登录和注销功能:

import cn.dev33.satoken.stp.StpUtil;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/user")
public class UserController {

    // 登录
    @GetMapping("/login")
    public String login(String username, String password) {
        // 模拟用户登录
        if ("admin".equals(username) && "123456".equals(password)) {
            StpUtil.login(1001); // 将用户 ID 存储到 Token 中
            return "登录成功";
        }
        return "登录失败";
    }

    // 注销
    @GetMapping("/logout")
    public String logout() {
        StpUtil.logout();
        return "注销成功";
    }

    // 检查是否登录
    @GetMapping("/checkLogin")
    public String checkLogin() {
        return "当前会话是否登录:" + StpUtil.isLogin();
    }
}

4. 权限校验

使用注解或代码实现权限校验:

  • 注解方式

    @SaCheckLogin
    @GetMapping("/info")
    public String info() {
        return "用户信息";
    }
    
    @SaCheckRole("admin")
    @GetMapping("/admin")
    public String admin() {
        return "管理员页面";
    }
    
    @SaCheckPermission("user:add")
    @GetMapping("/addUser")
    public String addUser() {
        return "添加用户";
    }
  • 代码方式

    @GetMapping("/info")
    public String info() {
        if (!StpUtil.isLogin()) {
            return "未登录";
        }
        return "用户信息";
    }

    Sa-Token 的高级功能

  • 多端登录

    • 支持同一用户在不同设备上登录,并为每个设备分配独立的 Token。

  • 踢人下线

    • 强制指定用户下线:

      StpUtil.kickout(1001); // 将用户 ID 为 1001 的用户踢下线
  • 分布式会话

    • 通过集成 Redis 实现分布式会话管理。

  • 路由拦截

    • 使用 Sa-Token 的拦截器实现全局权限校验。


Sa-Token 的优点

  • 简单易用:API 设计简洁,学习成本低。

  • 功能丰富:支持登录认证、权限认证、角色认证等多种功能。

  • 灵活扩展:支持自定义 Token 生成策略、会话存储策略等。

  • 性能高效:轻量级设计,性能优异。


官方资源

Sa-Token

<think>首先,用户的问题是:“我想了解如何在sa-token中使用sa-token-caffeine插件 请问sa-token 使用 sa-token-caffeine 插件的方法”。我需要基于系统指令回答。 系统指令的关键点: - 所有行内数学表达式用$...$格式。 - 独立公式用$$...$$格式并单独成段。 - LaTeX语法正确。 - 使用中文回答。 - 生成相关问题。 - 回答中引用的段落末尾自然地添加引用标识,如[^1]。 用户可见层指令: - 回答结构清晰,帮助用户逐步解决问题。 - 尽量保证回答真实可靠。 参考引用: - 引用[1]: Token设计信息,SA-Token框架介绍。 - 引用[2]: 获取Token信息的方法。 - 引用[3]: 插件注册方法,在resources/META-INF/satoken/下创建文件。 - 引用[4]: 配置项更新,支持在SaLoginParameter中定义。 用户的问题是关于使用sa-token-caffeine插件的具体方法。SA-Token是一个Java权限认证框架,而sa-token-caffeine插件可能是用于缓存Token的,因为Caffeine是一个高性能的Java缓存库。 我需要构建一个清晰的回答结构: 1. **介绍插件**:解释sa-token-caffeine插件的作用。 2. **安装和配置**:如何添加依赖和配置插件。 3. **使用示例**:展示代码示例。 4. **生成相关问题**:在回答末尾添加相关问题。 基于引用[3],插件注册需要创建文件在resources/META-INF/satoken/下指定注册类。 步骤: 1. **添加依赖**:在pom.xml中添加sa-token-caffeine插件的依赖。 2. **配置插件**:在配置文件中设置。 3. **注册插件**:创建文件指定注册类。 4. **代码使用**:展示如何获取Token信息等。 确保使用中文回答。 生成相关问题: - 例如:如何优化缓存性能?插件支持哪些功能? 最终回答结构: - 开头:解释插件作用。 - 步骤:逐步指导。 - 代码块:展示配置和代码。 - 结尾:添加相关问题。</think>### SA-Token 使用 sa-token-caffeine 插件的方法 sa-token-caffeine 插件是 SA-Token 框架的一个扩展组件,用于集成 Caffeine 缓存库,以提升 Token 存储和会话管理的性能。Caffeine 是一个高性能的 Java 缓存库,能有效减少数据库访问压力,适用于高并发场景。下面我将逐步介绍如何在 SA-Token 中使用该插件,确保结构清晰且基于官方文档[^3][^4]。 #### 步骤 1: 添加依赖 首先,在您的 Maven 项目(如 Spring Boot)的 `pom.xml` 文件中添加 sa-token-caffeine 插件的依赖。确保版本与 SA-Token 核心库兼容(推荐使用最新版本)。 ```xml <dependency> <groupId>cn.dev33</groupId> <artifactId>sa-token-caffeine</artifactId> <version>1.35.0</version> <!-- 替换为最新版本 --> </dependency> ``` #### 步骤 2: 配置插件注册 根据 SA-Token 插件机制,需要在 `resources` 目录下创建配置文件来注册插件: 1. 在 `resources/META-INF/satoken/` 文件夹下创建文件 `cn.dev33.satoken.plugin.SaTokenPlugin`。 2. 文件内容为该插件的完全限定类名: ``` cn.dev33.satoken.plugin.caffeine.SaTokenPluginCaffeine ``` 这会使 SA-Token 在启动时自动加载 Caffeine 缓存实现[^3]。 #### 步骤 3: 配置缓存参数 在 `application.yml`(或 `application.properties`)中添加 Caffeine 缓存配置。您可以自定义缓存大小、过期时间等,以优化性能。例如: ```yaml sa-token: # 启用 Caffeine 缓存 token-prefix: "satoken" timeout: 3600 # Token 默认过期时间(秒) caffeine: initial-capacity: 100 # 初始缓存容量 maximum-size: 1000 # 最大缓存条目数 expire-after-write: 1h # 写入后过期时间 ``` 此配置覆盖了 SA-Token 的默认缓存策略,使用 Caffeine 代替内存存储[^4]。 #### 步骤 4: 代码中使用 Token 功能 插件集成后,SA-Token 的 API 会自动使用 Caffeine 缓存。例如,获取 Token 信息或验证登录状态: ```java import cn.dev33.satoken.stp.StpUtil; public class AuthService { public void checkToken() { // 登录并生成 Token StpUtil.login(1001); // 假设用户ID为1001 // 获取当前 Token 值(从 Caffeine 缓存中读取) String tokenValue = StpUtil.getTokenValue(); System.out.println("Token 值: " + tokenValue); // 获取 Token 详细信息(包含过期时间等) SaTokenInfo tokenInfo = StpUtil.getTokenInfo(); System.out.println("剩余有效期: " + tokenInfo.getTokenTimeout() + "秒"); } } ``` - `StpUtil.getTokenInfo()` 返回的对象包含字段如 `tokenValue`、`loginId`、`tokenTimeout` 等,这些数据现在通过 Caffeine 缓存高效存储[^2]。 #### 注意事项 - **性能优化**:Caffeine 插件适合高并发系统,能减少数据库 I/O。测试时关注缓存命中率(hit rate),公式为:$ \text{hit rate} = \frac{\text{缓存命中次数}}{\text{总访问次数}} \times 100\% $。 - **兼容性**:确保 SA-Token 核心版本 ≥ 1.34.0,旧版本可能需要额外配置。 - **错误处理**:如果缓存未生效,检查注册文件路径是否正确,或添加日志调试。 通过以上步骤,您已成功集成 sa-token-caffeine 插件,提升了 Token 管理的效率和可扩展性。更多细节参考 SA-Token 官方文档[^1][^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值