循环引用:当一个对象包含另一个对象时,fastjson就会把该对象解析成引用。引用是通过$ref标示的,下面介绍一些引用的描述
“ r e f " : " . . " 上 一 级 " ref":".." 上一级 " ref":".."上一级"ref”:"@" 当前对象,也就是自引用
“ r e f " : " ref":" ref":"” 根对象
“ r e f " : " ref":" ref":".children.0” 基于路径的引用,相当于 root.getChildren().get(0)
fastjson提供了多种json转换方案,有兴趣的同学可以自己看看源码,这里我们可以采用禁止循环引用的方案:
String s = JSON.toJSONStringWithDateFormat(0,“yyyy-MM-dd HH:mm:ss”,SerializerFeature.DisableCircularReferenceDetect);
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
// 初始化转换器
FastJsonHttpMessageConverter fastConvert = new FastJsonHttpMessageConverter();
// 初始化一个转换器配置
FastJsonConfig fastJsonConfig = new FastJsonConfig();
JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd HH:mm";
fastJsonConfig.setSerializerFeatures(SerializerFeature.BrowserCompatible,
SerializerFeature.WriteNullListAsEmpty,
SerializerFeature.PrettyFormat,
SerializerFeature.WriteDateUseDateFormat,
SerializerFeature.WriteNullStringAsEmpty,
SerializerFeature.WriteMapNullValue,
SerializerFeature.DisableCircularReferenceDetect);
//解决Long转json精度丢失的问题
SerializeConfig serializeConfig = SerializeConfig.globalInstance;
serializeConfig.put(BigInteger.class, ToStringSerializer.instance);
serializeConfig.put(Long.class, ToStringSerializer.instance);
serializeConfig.put(Long.TYPE, ToStringSerializer.instance);
fastJsonConfig.setSerializeConfig(serializeConfig);
// 将配置设置给转换器并添加到HttpMessageConverter转换器列表中
fastConvert.setFastJsonConfig(fastJsonConfig);
converters.add(fastConvert);
}
下面是SerializerFeature中的参数类型感兴趣的通过可以了解下!
QuoteFieldNames,//输出key时是否使用双引号,默认为true
UseSingleQuotes,//使用单引号而不是双引号,默认为false
WriteMapNullValue,//是否输出值为null的字段,默认为false
WriteEnumUsingToString,//Enum输出name()或者original,默认为false
UseISO8601DateFormat,//Date使用ISO8601格式输出,默认为false
WriteNullListAsEmpty,//List字段如果为null,输出为[],而非null
WriteNullStringAsEmpty,//字符类型字段如果为null,输出为"",而非null
WriteNullNumberAsZero,//数值字段如果为null,输出为0,而非null
WriteNullBooleanAsFalse,//Boolean字段如果为null,输出为false,而非null
SkipTransientField,//如果是true,类中的Get方法对应的Field是transient,序列化时将会被忽略。默认为true
SortField,//按字段名称排序后输出。默认为false
@Deprecated
WriteTabAsSpecial,//把\t做转义输出,默认为false
PrettyFormat,//结果是否格式化,默认为false
WriteClassName,//序列化时写入类型信息,默认为false。反序列化是需用到
DisableCircularReferenceDetect,//消除对同一对象循环引用的问题,默认为false
WriteSlashAsSpecial,//对斜杠'/'进行转义
BrowserCompatible,//将中文都会序列化为\uXXXX格式,字节数会多一些,但是能兼容IE 6,默认为false
WriteDateUseDateFormat,//全局修改日期格式,默认为false。JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd";JSON.toJSONString(obj, SerializerFeature.WriteDateUseDateFormat);
NotWriteRootClassName,//暂不知,求告知
DisableCheckSpecialChar,//一个对象的字符串属性中如果有特殊字符如双引号,将会在转成json时带有反斜杠转移符。如果不需要转义,可以使用这个属性。默认为false
BeanToArray //暂不知,求告知
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
super.configureMessageConverters(converters);
FastJsonHttpMessageConverter fastConverter = new FastJsonHttpMessageConverter();
FastJsonConfig fastJsonConfig = new FastJsonConfig();
fastJsonConfig.setSerializerFeatures(SerializerFeature.BrowserCompatible,
SerializerFeature.WriteNullListAsEmpty,
SerializerFeature.PrettyFormat,
SerializerFeature.WriteDateUseDateFormat,
SerializerFeature.WriteNullStringAsEmpty,
SerializerFeature.WriteMapNullValue,
SerializerFeature.DisableCircularReferenceDetect);
fastConverter.setFastJsonConfig(fastJsonConfig);
converters.add(fastConverter);
}`