(五)spring cloud Feign 转发请求头(header参数)

 1. 实现Feign提供的一个接口RequestInterceptor

@Configuration
public class FeignConfiguration implements RequestInterceptor{
    private final Logger logger = LoggerFactory.getLogger(getClass());
 
            @Override
            public void apply(RequestTemplate template) {
                ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
                        .getRequestAttributes();
                HttpServletRequest request = attributes.getRequest();
                Enumeration headerNames = request.getHeaderNames();
                if (headerNames != null) {
                    while (headerNames.hasMoreElements()) {
                        String name = headerNames.nextElement();
                        String values = request.getHeader(name);
                        template.header(name, values);
 
                    }
                    logger.info("feign interceptor header:{}",template);
                }
            }
        }

 2.在@FeignClient注解里面的属性加上configuration = FeignConfiguration.class就可以了

@FeignClient(name = "aa.com",  configuration = FeignConfiguration.class)
public interface TESt{
}

3.yml文件配置

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

 

你可能感兴趣的:(spring,boot,spring,cloud)