首先,说一下出现问题的原因:后台传过去的json数据用了阿里巴巴的fastjson转换,但是有个问题就是:解析list中引用的数据时,jvm避免数据溢出,会自动处理为“循环引用”,因此,也就出现了问题的根源{"$ref":"$.data[0].task.OBJECTS[0]"},数据以引用的方式传给前台,前台却无法解析到那段引用的数据。
循环引用:当一个对象包含另一个对象时,fastjson就会把该对象解析成引用。
然后,知道了问题的根源,就知道往什么方向解决问题了--禁止循环引用。解决方案如下所示:
注:map中存放了你需要传到前台的数据对象:data!并且data中的对象数据存在循环引用。
网上的解决方案:
JSON.toJSONString(list,SerializerFeature.DisableCircularReferenceDetect)
注:不管你是引用JSON,还是JSONObject,主要是看你想传的对象是啥类型,然后转换成JSON / JSONObject
下面介绍一些引用的描述:
- "$ref":".." 上一级
- "$ref":"@" 当前对象,也就是自引用
- "$ref":"$" 根对象
- "$ref":"$.children.0" 基于路径的引用,相当于 root.getChildren().get(0)
下面是SerializerFeature中的参数类型,感兴趣的同学可以了解一下!(当然,最主要的还是记下来,有备自己以后查看,233 ~:)
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 //暂不知,求告知