sa-token/sa-token-doc/micro/import-intro.md
2022-10-10 00:59:08 +08:00

2.4 KiB
Raw Blame History

微服务中使用Sa-Token 依赖引入说明


虽然在 [开始] 章节已经说明了依赖引入规则但是交流群里不少小伙伴提出bug解决到最后发现都是因为依赖引入错误导致的此处再次重点强调一下

在微服务架构中使用Sa-Token时网关和内部服务要分开引入Sa-Token依赖不要直接在顶级父pom中引入Sa-Token

总体来讲,我们需要关注的依赖就是两个:sa-token-spring-boot-startersa-token-reactor-spring-boot-starter

<!-- Sa-Token 权限认证, 在线文档http://sa-token.dev33.cn/ -->
<dependency>
    <groupId>cn.dev33</groupId>
    <artifactId>sa-token-spring-boot-starter</artifactId>
    <version>${sa.top.version}</version>
</dependency>
<!-- Sa-Token 权限认证Reactor响应式集成, 在线文档http://sa-token.dev33.cn/ -->
<dependency>
    <groupId>cn.dev33</groupId>
    <artifactId>sa-token-reactor-spring-boot-starter</artifactId>
    <version>${sa.top.version}</version>
</dependency>

至于怎么分辨我们需要引入哪个呢?这个要看你使用的基础框架:

对于内部基础服务来讲我们一般都是使用SpringBoot默认的web模块SpringMVC 因为这个SpringMVC是基于Servlet模型的在这里我们需要引入的是sa-token-spring-boot-starter

对于网关服务,大体来讲分为两种:

  • 一种是基于Servlet模型的Zuul我们需要引入的是sa-token-spring-boot-starter,详细戳:在SpringBoot环境集成
  • 一种是基于Reactor模型的SpringCloud Gateway、ShenYu 等等,我们需要引入的是:sa-token-reactor-spring-boot-starter并且注册全局过滤器!,详细戳:在WebFlux环境集成

注:切不可直接在一个项目里同时引入这两个依赖,否则会造成项目无法启动

另外我们需要引入Redis集成包因为我们的网关和子服务主要通过Redis来同步数据

<!-- Sa-Token 整合 Redis (使用jackson序列化方式) -->
<dependency>
    <groupId>cn.dev33</groupId>
    <artifactId>sa-token-dao-redis-jackson</artifactId>
    <version>${sa.top.version}</version>
</dependency>
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
</dependency>

详细参考:集成 Redis