openfeign调用 HttpServletRequest作为参数 报错..

1. 问题起因

  • 需要将业务数据放入HttpServletRequest的请求头里面。
  • 被调用的模块,rest接口设计是以HttpServletRequest作为 参数的。
  • 于是夫,秉信feign的接口设计必须和提供者参数一样。
  • 消费者调用feign接口,报一堆奇奇怪怪的错误。报错Jackson中的错误…

2. 问题分析

  1. feign接口是不支持HttpServletRequest作为参数的
  2. feign和hystrix整合开启了feign对hystrix的熔断,导致feign的拦截器获取不到请求

3. 问题解决

  • 问题1解决, 使用feign的拦截器,将请求拦截下

    package top.bitqian.config;
    
    import feign.RequestInterceptor;
    import feign.RequestTemplate;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.context.request.RequestContextHolder;
    import org.springframework.web.context.request.ServletRequestAttributes;
    
    import javax.servlet.http.HttpServletRequest;
    import java.util.Enumeration;
    import java.util.LinkedHashMap;
    import java.util.Map;
    import java.util.Objects;
    
    /**
     * @author echo lovely
     * @date 2021/2/1 20:45
     */
    @Configuration
    public class FeignConfig implements RequestInterceptor {
            /**
             * 复写feign请求对象
             * @param requestTemplate hhh
             */
            @Override
            public void apply(RequestTemplate requestTemplate) {
                //获取请求头
                Map<String,String> headers = getHeaders(Objects.requireNonNull(getHttpServletRequest()));
                for(String headerName : headers.keySet()){
                    requestTemplate.header(headerName, getHeaders(getHttpServletRequest()).get(headerName));
                }
            }
            //获取请求对象
            private HttpServletRequest getHttpServletRequest() {
                try {
                    return ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
                } catch (Exception e) {
                    e.printStackTrace();
                    return null;
                }
            }
            //拿到请求头信息
            private Map<String, String> getHeaders(HttpServletRequest request) {
                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;
            }
    
    }
    
    

这样feign接口中,就不用写HttpServletRequest 请求了,请求会通过feign发送到提供者。


  • 问题二解决:造成原因,feing.hystrix.enabled=true, 开启了熔断

  • 解决,将上面配置更换为:

    hystrix:
      command:
        default:
          execution:
            isolation:
              strategy: SEMAPHORE
    

参考:
https://www.jianshu.com/p/3b34234c4623

https://blog.csdn.net/cgd_8523/article/details/100575915

https://blog.csdn.net/liu_ares/article/details/100371441

  • 10
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值