如果项目中用的是 HttpClient 或者 RestTemplate 之类的调用接口,则可以在调用之前申请 Token,然后将其塞到请求头中。

Spring Cloud 中消费接口肯定是用 Feign 来做的,这意味着我们需要对 Feign 进行改造,需要往请求头中塞上我们申请好的 Token。

1. 定义请求拦截器

对于 Token 的传递操作,最好在框架层面进行封装,对使用者透明,这样不影响业务代码,但要求通用性一定要强。我们可以定义一个 Feign 的请求拦截器来统一添加请求头信息,代码如下所示。

  1. /**
  2. * Feign 请求拦截器
  3. **/
  4. public class FeignBasicAuthRequestInterceptor implements RequestInterceptor {
  5. public FeignBasicAuthRequestInterceptor() {
  6. }
  7. @Override
  8. public void apply(RequestTemplate template) {
  9. template.header("Authorization", System.getProperty("fangjia.auth.token"));
  10. }
  11. }

2. 配置拦截器

拦截器需要在 Feign 的配置中定义,代码如下所示。

  1. @Configuration
  2. public class FeignConfiguration {
  3. /**
  4. * 日志级别
  5. *
  6. * @return
  7. */
  8. @Bean
  9. Logger.Level feignLoggerLevel() {
  10. return Logger.Level.FULL;
  11. }
  12. /**
  13. * 创建 Feign 请求拦截器, 在发送请求前设置认证的 Token, 各个微服务将 Token 设置 到环境变量中来达到通用的目的
  14. *
  15. * @return
  16. */
  17. @Bean
  18. public FeignBasicAuthRequestInterceptor basicAuthRequestInterceptor() {
  19. return new FeignBasicAuthRequestInterceptor();
  20. }
  21. }

上面的准备好之后,我们只需要在调用业务接口之前先调用认证接口,然后将获取到的 Token 设置到环境变量中,通过 System.setProperty(“fangjia.auth.token”,token) 设置值,或者通过定时任务刷新设置。

这样我们就可以通过 System.setProperty(“fangjia.auth.token”,token) 获取到需要传递的 Token。