使用RequestInterceptor拦截器实现request转发,这样可以完美解决请求头传递以及参数过滤问题
但是有个坑的问题 在和文件上传一起使用会有问题;
还有feign文件上传时候,需要一个form编码器,实现支持form表单提交
@Configuration
public class FeginInterceptor implements RequestInterceptor {
@Autowired
private ObjectFactory<HttpMessageConverters> messageConverters;
@Override
public void apply(RequestTemplate requestTemplate) {
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);
//解决图片上传 防止请求头Content-Type的boundary被更改
if ("Content-Type".equals(name)) {
continue;
}
requestTemplate.header(name, values);
}
}
}
@Bean
@Primary
@Scope("prototype")
public Encoder feignEncoder() {
return new SpringFormEncoder(new SpringEncoder(messageConverters));
}
}
这里需要注意在RequestInterceptor转发时候将Content-Type过滤,为什么要这样操作呢?当用户提交到微服务API时,分隔符boundary是用户那边生成;在API通过fegin调用其他文件上传微服务时候,也会生成一个新boundary分隔符,两个导致boundary分隔符不同导致微服务那边接受到MultipartFile是null。只需要在转换请求头转发时候过滤掉"Content-Type"即可。。
if(“Content-Type”.equals(name)){
continue;
}
通过RequestInterceptor转发过滤时候会将之前的
Content-Type=[multipart/form-data; charset=UTF-8; boundary=16cd63fb250], Content-Length=[205222]
转换成
Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryQjcySmVgZu68XASN
导致通过feign请求时候传递MultipartFile文件是null的问题;