FeignRequestInterceptor.java 1.9 KB
Newer Older
1 2 3 4 5 6
package cn.ibizlab.util.web;

import feign.RequestInterceptor;
import feign.RequestTemplate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
7 8
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
9
import org.springframework.context.annotation.Configuration;
10 11 12
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
import org.springframework.util.ObjectUtils;
13 14 15 16
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import java.util.Enumeration;
17
import java.util.LinkedHashMap;
18 19 20 21 22 23 24 25 26 27

/**
 * feign请求拦截器
 * 拦截所有使用feign发出的请求,附加原始请求Header参数及Token
 */
@Configuration
public class FeignRequestInterceptor implements RequestInterceptor {

    private final Logger logger = LoggerFactory.getLogger(getClass());

28

29 30 31
    @Override
    public void apply(RequestTemplate requestTemplate) {
        ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
32
        if (requestAttributes != null) {
33 34 35 36 37
            HttpServletRequest request = requestAttributes.getRequest();
            Enumeration<String> headerNames = request.getHeaderNames();
            if (headerNames != null) {
                while (headerNames.hasMoreElements()) {
                    String name = headerNames.nextElement();
38
                    if (name.equalsIgnoreCase("transfer-encoding")) {
39 40 41 42 43
                        continue;
                    }
                    String values = request.getHeader(name);
                    requestTemplate.header(name, values);
                }
44
                logger.info("feign interceptor header:{}", requestTemplate);
45 46 47 48
            }
        }
    }
}