首先,说一下出现问题的原因:后台传过去的json数据用了阿里巴巴的fastjson转换,但是有个问题就是:解析list中引用的数据时,jvm避免数据溢出,会自动处理为“循环引用”,因此,也就出现了问题的根源{"$ref":"$.data[0].task.OBJECTS[0]"},数据以引用的方式传给前台,前台却无法解析到那段引用的数据。

循环引用:当一个对象包含另一个对象时,fastjson就会把该对象解析成引用。

然后,知道了问题的根源,就知道往什么方向解决问题了--禁止循环引用。解决方案如下所示

fastapi中如何把BaseModel定义的类获取字段 fastjson获取list_数据

注:map中存放了你需要传到前台的数据对象:data!并且data中的对象数据存在循环引用。

网上的解决方案:

JSON.toJSONString(list,SerializerFeature.DisableCircularReferenceDetect)

注:不管你是引用JSON,还是JSONObject,主要是看你想传的对象是啥类型,然后转换成JSON / JSONObject

 

下面介绍一些引用的描述:

  1. "$ref":".." 上一级
  2. "$ref":"@" 当前对象,也就是自引用
  3. "$ref":"$" 根对象
  4. "$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 //暂不知,求告知