假设我有以下 json 结构:
{
"Role": {
"id": "5",
"name": "bb1",
"description": "desc1",
"PermissionDeck": [
{
"id": "7",
"Permission": [
{
"id": "398"
},
{
"id": "399"
},
{
"id": "400"
},
{
"id": "401"
},
{
"id": "402"
}
],
"Limit": [
{
"id": "4"
},
{
"id": "5"
}
]
}
]
}
}
如果我想将其转换为 LinkedTreeMap 结果
,以便可以通过以下方式检索其内容:
result.get("Role")
返回 Map
和
result.get("Role").get("PermissionDeck").size() == 5
和
result.get("Role").get("PermissionDeck").get(0).get("id") == 398
基本上使 gson.fromjson 递归地进入结构,并将任何嵌套结构折叠到 LinkedTreeMap 中,直到到达最内层,然后进入 LinkedTreeMap
如果不编写自定义递归方法,这可能吗?
最佳答案
你不能。最接近的是使用 JsonObject
并为每个嵌套成员使用适当的 getter。换句话说,您的代码需要明确说明它在 JSON 中所期望的内容。
例如
JsonObject result = new Gson().fromJson(theJson), JsonObject.class);
System.out.println(result.getAsJsonObject("Role").getAsJsonArray("PermissionDeck").size());
将打印 1
,因为在根 JSON 对象中名为 Role
的 JSON 对象中,名为 PermissionDeck
的 JSON 数组中只有一个元素.
关于java - 如何使用 gson.fromjson 递归地转换 json,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32337617/