[
{
"@id": "1",
"name": "Sally",
"secretSanta": {
"@id": "2",
"name": "Bob",
"secretSanta": {
"@id": "3",
"name": "Fred",
"secretSanta": { "@ref": "1" }
}
}
},
{ "@ref": "2" },
{ "@ref": "3" }
]
JSON数据中遇到类似的数据是由于后端获取数据时采用的是jpa持久层框架
使用jpa查询对象时,jpa会把该对象的关联对象也会进行查询。如对象A关联了对象B,对象B关联了对象C,对象C又关联到了对象A。即A->B->C->A。那么查询结果必然是个死循环。所以为了解决这个问题,Java可以在实体中打上如下注解
@JsonIdentityInfo(generator=JSOGGenerator.class)
来解决这个死循环问题。 此时查询出来的对象序列化后就会与开头的对象相类似,含有@id和@ref属性。@ref代表的是当前对象在之前已经出现过(例如@ref:1 前面必然有个@id:1,@id 定义必须在 @ref 引用之前)。在我看来其实是采用了一种引用递归的方式来解决数据死循环的问题。此时想要解析数据可以引用JSOG来对JSON进行处理,把它还原到我们所熟悉的JSON对象。
JSOG具体使用方法可参考https://github.com/jsog/jsog
(ps:以上文章仅代表个人看法,如有不对之处欢迎指出!)