網上有很多介紹,主要有兩種。
1.在啟動類中注入bean
/**
* 集成fastjson
*
* @return
*/
@Bean
public HttpMessageConverters fastJsonHttpMessageConverters() {
// 1. 需要定義一個converter轉換消息的對象
FastJsonHttpMessageConverter fasHttpMessageConverter = new FastJsonHttpMessageConverter();
// 2. 添加fastjson的配置信息,比如:是否需要格式化返回的json的數據
FastJsonConfig fastJsonConfig = new FastJsonConfig();
fastJsonConfig.setSerializerFeatures(SerializerFeature.PrettyFormat);
// 3. 在converter中添加配置信息
fasHttpMessageConverter.setFastJsonConfig(fastJsonConfig);
HttpMessageConverter<?> converter = fasHttpMessageConverter;
return new HttpMessageConverters(converter);
}
2.繼承WebMvcConfigurerAdapter,重寫方法
WebMvcConfigurerAdapter 已經過期,改由 WebMvcConfigurationSupport 繼承
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
super.configureMessageConverters(converters);
// 1.需要先定義一個convert 轉換消息的對象
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
// 2.添加fastJson的配置信息,比如,是否需要格式化返回的json數據
FastJsonConfig fastJsonConfig = new FastJsonConfig();
// 空值特別處理
// WriteNullListAsEmpty 將Collection類型字段的字段空值輸出為[]
// WriteNullStringAsEmpty 將字符串類型字段的空值輸出為空字符串 ""
// WriteNullNumberAsZero 將數值類型字段的空值輸出為0
// WriteNullBooleanAsFalse 將Boolean類型字段的空值輸出為false
fastJsonConfig.setSerializerFeatures(SerializerFeature.PrettyFormat, SerializerFeature.WriteNullListAsEmpty,
SerializerFeature.WriteNullStringAsEmpty);
// 處理中文亂碼問題
List<MediaType> fastMediaTypes = new ArrayList<>();
fastMediaTypes.add(MediaType.APPLICATION_JSON_UTF8);
fastConverter.setSupportedMediaTypes(fastMediaTypes);
// 3.在convert中添加配置信息
fastConverter.setFastJsonConfig(fastJsonConfig);
// 4.將convert添加到converters當中
converters.add(fastConverter);
}
我一開始在啟動類用的是第一種方法,不成功,用第二種也是不成功 ,試了很多次,還是失敗。
突然想起一件事件,我用了攔截器,里面有一個類繼承了WebMvcConfigurationSupport,是不是這個類搞得。
於是把啟動類中集成代碼轉移到這個攔截器中,一切OK了。
攔截器中,只能有一個類集成WebMvcConfigurationSupport,出現多個類集成WebMvcConfigurationSupport時,配置是不生效的
巨坑
轉自:https://www.cnblogs.com/huiy/p/9035611.html
非常感謝,被折磨了好久

