spring cloud feign 调用微服务转发不了request请求头和参数问题解决方案
方法一
@Configuration
public class FeignConfiguration {
private Logger logger = LoggerFactory.getLogger(FeignConfiguration.class);
@Bean
public RequestInterceptor requestInterceptor() {
return new RequestInterceptor() {
@Override
public void apply(RequestTemplate template) {
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
Enumeration<String> headerNames = request.getHeaderNames();
if (headerNames != null) {
while (headerNames.hasMoreElements()) {
String name = headerNames.nextElement();
String values = request.getHeader(name);
template.header(name, values);
}
}
Enumeration<String> bodyNames = request.getParameterNames();
StringBuffer body =new StringBuffer();
if (bodyNames != null) {
while (bodyNames.hasMoreElements()) {
String name = bodyNames.nextElement();
String values = request.getParameter(name);
body.append(name).append("=").append(values).append("&");
}
}
if(body.length()!=0) {
body.deleteCharAt(body.length()-1);
template.body(body.toString());
logger.info("feign interceptor body:{}",body.toString());
}
}
};
}
}
方法二
不需要修改配置拦截,可以使用自定义参数传值的方式也是可以的,例如封装一个实体类,调用夸服务接口的时候直接传这个带有会话信息的实体类过去就可以了
备注:方法一适用于所有的java web项目,但是当关联微信小程序这一块的时候,会出现取不到值得情况,于是才考虑第二种方式操作,如果各位码友有更好的方式,欢迎留言。