網上有很多介紹,主要有兩種。
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了。