我是靠谱客的博主 想人陪芒果,这篇文章主要介绍RequestInterceptor过滤器,微服务之间feign调用请求头丢失的问题,现在分享给大家,希望可以做个参考。

    /**
     * 微服务之间传递的唯一标识
     */
    public static final String X_REQUEST_ID = "X-Request-Id";

    @Override
    public void apply(RequestTemplate template) {
        HttpServletRequest httpServletRequest = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes())
        .getRequest();
        if (httpServletRequest != null) {
             
            Map<String, String> headers = getHeaders(httpServletRequest);
            // 传递所有请求头,防止部分丢失
            for (Map.Entry<String, String> entry : headers.entrySet()) {
                // 防止添加重复
                if (!template.headers().containsKey(entry.getKey())) {
                    template.header(entry.getKey(), entry.getValue());
                }
            }
            // 微服务之间传递的唯一标识,区分大小写所以通过httpServletRequest查询
            if (headers.containsKey(X_REQUEST_ID)) {
                String traceId = headers.get(X_REQUEST_ID);
                //不做处理
//                MDC.put("traceId", traceId);
                log.info("FeignRequestInterceptor X-Request-Id:{}", traceId);
            }
            if (log.isDebugEnabled()) {
                log.debug("FeignRequestInterceptor:{}", template.toString());
            }
        }
    }

private Map<String, String> getHeaders(HttpServletRequest request) {
    Map<String, String> map = new LinkedHashMap<>();
    Enumeration<String> enumeration = request.getHeaderNames();
    if (enumeration != null) {
        while (enumeration.hasMoreElements()) {
            String key = enumeration.nextElement();
            String value = request.getHeader(key);
            map.put(key, value);
        }
    }
    return map;
}

最后

以上就是想人陪芒果最近收集整理的关于RequestInterceptor过滤器,微服务之间feign调用请求头丢失的问题的全部内容,更多相关RequestInterceptor过滤器,微服务之间feign调用请求头丢失内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(46)

评论列表共有 0 条评论

立即
投稿
返回
顶部