如何使用springcloud+oauth2携带token去请求其他服务

2021/8/27 22:16:02
栏目: 其他类
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

小编给大家分享一下如何使用springcloud+oauth2携带token去请求其他服务,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

springcloud+oauth3携带token去请求其他服务

当从oauth3服务中获取到了token后

携带该token去请求其他服务时,报出

{
    "error": "invalid_token",
    "error_description": "Invalid access token: e5224346-ea39-49ff-bd0e-1b9aef3db1da"}

需要在当前服务的配置文件配置

#内置有user对象的地址,才能获取到同一个tokensecurity.oauth3.resource.user-info-uri=http://localhost:8003/api/usersecurity.oauth3.resource.prefer-token-info=false

springcloud 微服务之间传递token

在springcloud 微服务中大部分是通过token来验证用户的,那么有个问题,假设现在有A服务,B服务,外部使用RESTApi请求调用A服务,在请求头上有token字段,A服务使用完后,B服务也要使用,如何才能把token也转发到B服务呢,最差的解决办法就是吧token放到请求参数中,但是这样第一个是明文传输,第二个是比较麻烦,前端每次都要加个参数。

这里可以使用Feign的RequestInterceptor,把request里的请求参数包括请求头全部复制到feign的request里,但是直接使用一般情况下HttpServletRequest上下文对象是为空的,其实加个配置就可以解决。

1、服务A中 application.yml 加入如下配置

hystrix:  command:    default:      execution:        isolation:          strategy: SEMAPHORE  #加上这个就可以获取到HttpServletRequest          thread:            timeoutInMilliseconds: 10000

2、服务A中加入 FeginInterceptor

@Configurationpublic class FeginInterceptor implements RequestInterceptor {
    @Override    public void apply(RequestTemplate requestTemplate) {
       try {
           Map<String,String> headers = getHeaders();
           for(String headerName : headers.keySet()){
               requestTemplate.header(headerName, headers.get(headerName));
           }
       }catch (Exception e){
           e.printStackTrace();
       }
    }
    private Map<String, String> getHeaders(){
        HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
        Map<String, String> map = new LinkedHashMap<>();
        Enumeration<String> enumeration = request.getHeaderNames();
        while (enumeration.hasMoreElements()) {
            String key = enumeration.nextElement();
            String value = request.getHeader(key);
            map.put(key, value);
        }
        return map;
    }
}

若服务B或C也想传递token,加上上述A配置即可~

看完了这篇文章,相信你对“如何使用springcloud+oauth2携带token去请求其他服务”有了一定的了解,如果想了解更多相关知识,欢迎关注辰迅云资讯频道,感谢各位的阅读!


辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: Samza怎么与RabbitMQ集成