spring cloud fegin传递request header

1、概述

今天一个朋友, 遇到一个如何在使用spring cloud feign 传递token 等参数问题。

2、解决方案

2.1 创建类继承RequestInterceptor

创建类继承RequestInterceptor 具体如下代码所示:

public class FeginInterceptor implements RequestInterceptor {
    @Override
    public void apply(RequestTemplate requestTemplate) {
        Map<String,String> headers = getHeaders();
        for(String headerName : headers.keySet()){
            requestTemplate.header(headerName, getHeaders().get(headerName));
        }
    
    /**
	 *  返回所有header 中的数据
	 *   Return 
	 */
    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;
    }
}
2.2 在@configuration 类中定义其
@Configuration
public class FeginSupportHeader {
	@Bean
	public RequestInterceptor getRequestInterceptor(){
	    return new FeginInterceptor();
	}
}

2.3 在yml 或者properties 中添加下面关键配置

# To set thread isolation to SEMAPHORE
hystrix:
  command:
    default:
      execution:
        isolation:
          strategy: SEMAPHORE

3、总结

按照上面的操作就可以将上一个服务或者是前端传递过来的header参数传递到下一个服务中去。
需要注意的是, 每个请求都会拦截设置上header信息。

4. 参考地址

http://cloud.spring.io/spring-cloud-openfeign/single/spring-cloud-openfeign.html

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值