HttpMessageConverter 是SpringMVC中提供的一个策略接口,它是一个消息转换器类,Spring Mvc中就是由HttpMessageConverter负责转换HTTP的请求和响应。
默认情况下,Spring Boot 会自动加载如下消息类型转换器:

常见消息类型转换器介绍:
利用SpringMVC框架,可以使得我们在开发时,只要在代码中使用@RequestBody和@ResponseBody两个注解,就可以分别完成从请求报文到对象和从对象到响应报文的转换。而在源码内部,其实这种灵活的消息转换机制就是利用HttpMessageConverter来实现的。
HttpMessageConverter的调用是RequestResponseBodyMethodProcessor类的解析请求参数的方法resolveArgument()和处理返回值的方法handleReturnValue()中进行调用的。这是关于@RequestBody和@ResponseBody两个注解的原理。

public interface HttpMessageConverter {
boolean canRead(Class> clazz, @Nullable MediaType mediaType);
boolean canWrite(Class> clazz, @Nullable MediaType mediaType);
List getSupportedMediaTypes();
default List getSupportedMediaTypes(Class> clazz) {
return (canRead(clazz, null) || canWrite(clazz, null) ?
getSupportedMediaTypes() : Collections.emptyList());
}
T read(Class extends T> clazz, HttpInputMessage inputMessage)
throws IOException, HttpMessageNotReadableException;
void write(T t, @Nullable MediaType contentType, HttpOutputMessage outputMessage)
throws IOException, HttpMessageNotWritableException;
}
消息转换器是在项目启动的时候通过WebMvcConfigurationSupport进行加载,当getMessageConverters()被调用的时候会通过configureMessageConverters()、addDefaultHttpMessageConverters()和extendMessageConverters()三个方法进行初始话消息转换器。生成的消息转换器放在List
protected final List> getMessageConverters() {
if (this.messageConverters == null) {
this.messageConverters = new ArrayList();
// 加载委托给WebMvcConfigurer类型的Bean
this.configureMessageConverters(this.messageConverters);
if (this.messageConverters.isEmpty()) {
// 加载默认的转换器
this.addDefaultHttpMessageConverters(this.messageConverters);
}
// 加载扩展消息转换器
this.extendMessageConverters(this.messageConverters);
}
return this.messageConverters;
}
@Configuration
public class CustomWebMvcConfigurer implements WebMvcConfigurer {
/**
* 直接注入 HttpMessageConverters
*/
@Bean
public HttpMessageConverters customConverters() {
return new HttpMessageConverters(configFastJsonHttpMessageConverter());
}
/**
* 实现 WebMvcConfigurer#extendMessageConverters 接口
*/
@Override
public void extendMessageConverters(List> converters) {
// 注意加载顺序
converters.add(0, configFastJsonHttpMessageConverter());
}
/**
* 配置JSON 消息转换器
*/
private HttpMessageConverter