一、携带 Token 的服务调用
重要提示,别乱加 inner 注解,别偷懒
使用 token 调用时,无需添加 @Inner、FROM_IN 或 @NoToken 等注解!
- 客户端携带 token 访问服务 A
- 服务 A 通过 FeignClient 调用服务 B 获取数据
- Token 会在整个调用链路中自动传递(A→B→C→D)
- 用户需要拥有调用链路上所有接口的访问权限
二、无 Token 的服务调用
在以下场景中,通常无法携带用户 token:
- 异步任务调用
- 定时任务调用
- 消息队列(MQ)调用
- 未登录状态的接口调用
实现方式
1. 调用方配置
在 FeignClient 接口中,需要通过以下方式之一声明无 token 调用:
方式一:使用 FROM_IN 参数(通用方式)
方式二:使用 @NoToken 注解(v5.6+ 版本支持)
2. 服务提供方配置
使用 @Inner 注解标记接口,实现内部调用控制:
@Inner 注解确保接口只能被内部服务调用,防止接口被外部直接访问,提升系统安全性。