feign调用 服务内无token_SpringSecurityOAuth2(9) feign 微服务间调用 token验证

Feign可以调用其他微服务的api接口,当其他服务没有权限验证的时候可以直接调用,但是调用服务存在权限拦截的话,就无法正常调用。本文讲的就是Feign调用认证api的一种方式。

首先新建一个fp-resouce-feign模块做调用测试,本模块不加OAuth2的拦截。

pom.xml增加常规依赖以及Feign的依赖

org.springframework.cloud

spring-cloud-starter-openfeign

在启动文件上加上@EnableFeignClients 注解表示启用Feign;

新建一个简单的Feign调用,这里我们调用manager服务,该服务增加了SpringSecurityOAuth2的权限拦截

@FeignClient(value = "manager")

public interface ResourceManagerFeignClient {

@GetMapping(value = "/auth/hello")

String hello();

}

对有权限处理的服务接口直接调用会造成调用时出现http 401未授权的错误,继而导致最终服务的http 500内部服务器错误

请求示例如图:

最方便的方案就是咋请求头上加上认证token信息,Feign 有一个接口 RequestInterceptor,做一些简单的添加token处理即可调用服务接口:

@Configuration

public class FeignConfig

你可能感兴趣的:(feign调用,服务内无token)