问题
导入文件接口报错
web请求A服务调用B服务
B服务报错如下:
org.springframework.web.HttpMediaTypeNotSupportedException: Content type 'multipart/form-data;boundary=--------------------------473858664983319617284770;charset=UTF-8' not supported
at org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodArgumentResolver.readWithMessageConverters(AbstractMessageConverterMethodArgumentResolver.java:237)
at org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.readWithMessageConverters(RequestResponseBodyMethodProcessor.java:150)
at org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.resolveArgument(RequestResponseBodyMethodProcessor.java:128)
at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:121)
at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:158)
at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128)
at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)
at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)
at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872)
排查
环境:springboot版本1.x sleuth版本1.x
通过调试发现sleuth复用上一个请求头内容调用下一链路服务报错
解决
去除feign调用中错误请求头
@Configuration
public class ClientConfiguration {
@Bean
public RequestInterceptor headerInterceptor() {
return new RequestInterceptor() {
@Override
public void apply(RequestTemplate template) {
HttpServletRequest httpServletRequest = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
if (httpServletRequest.getRequestURI().contains(template.url())) {
try {
Field connectorField = ReflectionUtils.findField(SecurityContextHolderAwareRequestWrapper.class, "request");
connectorField.setAccessible(true);
FirewalledRequest firewalledRequest = (FirewalledRequest) connectorField.get(httpServletRequest);
if(Objects.isNull(firewalledRequest))
return;
Field firewalledField = ReflectionUtils.findField(FirewalledRequest.class, "request");
firewalledField.setAccessible(true);
RequestFacade requestFacade = (RequestFacade) firewalledField.get(firewalledRequest);
if(Objects.isNull(requestFacade))
return;
connectorField = ReflectionUtils.findField(RequestFacade.class, "request");
firewalledField.setAccessible(true);
Request connectorRequest = (Request) connectorField.get(requestFacade);
if(Objects.isNull(connectorRequest))
return;
Field coyoteField = ReflectionUtils.findField(Request.class, "coyoteRequest", org.apache.coyote.Request.class);
coyoteField.setAccessible(true);
org.apache.coyote.Request coyoteRequest = (org.apache.coyote.Request) coyoteField.get(connectorRequest);
if(Objects.isNull(coyoteRequest))
return;
Field mimeHeadersField = ReflectionUtils.findField(org.apache.coyote.Request.class, "headers", MimeHeaders.class);
mimeHeadersField.setAccessible(true);
MimeHeaders mimeHeaders = (MimeHeaders) mimeHeadersField.get(coyoteRequest);
mineHeadersHandle(mimeHeaders);
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
};
}
protected static void mineHeadersHandle(MimeHeaders mimeHeaders) {
mimeHeaders.removeHeader(HttpHeaders.CONTENT_TYPE);
}
}
更
上面代码为小丑局 优化后链接
https://blog.csdn.net/qq_35764295/article/details/123581222