[英]Altering an array in a nested JSON object using Jackson
我试图通过指定该数组的路径来弄清楚如何更改JSON数组中的现有对象。
问题是我不知道如何指定数组的路径,以便可以更改它。 我在那里尝试的每个方法都没有关于如何更改ObjectNode中的数组的示例。
这是我现在的代码,在其中我尝试通过指针表示法指定数组的路径来获取和更改数组,但是,这总是不返回数组:
构建POJO类不是一种选择。
我的json结构中的数组如下:
{
RESULTS: {
ATTACHMENTS: {
ATTACHMENT: [{object}]
}
}
}
码:
private JsonNode attachmentConversion(JsonNode object){
final String ATTACHMENT_POINTER = "/RESULTS/ATTACHMENTS/ATTACHMENT"; //Path to the array
ObjectNode OUTPUT = object.deepCopy();
OUTPUT.remove("DETAILS");
//Validate is an array - It properly fetches the array
if(object.at(ATTACHMENT_POINTER).isArray()){
int counter=0;
//Loop through attachment array - It properly fethes each object in the array
for(final JsonNode objNode : object.at(ATTACHMENT_POINTER)){
ObjectNode objectNode = objNode.deepCopy();
OUTPUT.withArray(ATTACHMENT_POINTER) //HERE IS THE PROBLEM - How do I specify the path to the array I want to replace with a new object in the withArray api? This always returns back as an empty array, even though the loop above properly fetches the array elements.
.set(counter
, objectNode
.replace("ATTACH_CONTENT"
, xmlToJson.parseXmlToJson(objNode.get("ATTACH_CONTENT")
.asText())));
counter = counter+1;
}
}
return new ObjectMapper()
.createObjectNode()
.set("customertopology", OUTPUT);
}
我认为你不想改变传递给方法的对象,所以你做了一个深层复制。 并且您想要返回一个新的JSON对象。
我到目前为止对吗? 如果是,则在创建深层副本时,使用它,遍历所关注数组的每个元素,并将Node值替换为您想要的值。
private static JsonNode attachmentConversion(JsonNode object){
final String ATTACHMENT_POINTER = "/RESULTS/ATTACHMENTS/ATTACHMENT"; //Path to the array
ObjectNode OUTPUT = object.deepCopy();
OUTPUT.remove("DETAILS");
//Validate is an array - It properly fetches the array
if(OUTPUT.at(ATTACHMENT_POINTER).isArray()){
int counter=0;
//Loop through attachment array - It properly fethes each object in the array
for(final JsonNode objNode : OUTPUT.at(ATTACHMENT_POINTER)){
((ObjectNode)objNode).replace("ATTACH_CONTENT", xmlToJson.parseXmlToJson(objNode.get("ATTACH_CONTENT"));
}
}
return new ObjectMapper()
.createObjectNode()
.set("customertopology", OUTPUT);
}
你可以做到,而不是提供整个路径
OUTPUT.get("RESULTS").get("ATTACHMENTS").get("ATTACHMENT");
这应该返回数组。 使用fasterxml的完整代码
String json = "{\n" +
" \"RESULTS\": {\n" +
" \"ATTACHMENTS\": {\n" +
" \"ATTACHMENT\": [{\"key\": 1}, {\"key\": 2}]\n" +
" }\n" +
" }\n" +
"}";
ObjectMapper mapper = new ObjectMapper();
JsonNode node = mapper.readTree(json);
node.get("RESULTS").get("ATTACHMENTS").get("ATTACHMENT").forEach(obj -> {
System.out.println(obj.get("key"));
});
以下代码打印对我来说也是如此。
System.out.println(node.at("/RESULTS/ATTACHMENTS/ATTACHMENT").isArray());
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.