肯定存在一种方法来查询Json并使用JsonPath返回Json.
见下面的例子:
String jsonString = "{\"delivery_codes\": [{\"postal_code\": {\"district\": \"Ghaziabad\", \"pin\": 201001, \"pre_paid\": \"Y\", \"cash\": \"Y\", \"pickup\": \"Y\", \"repl\": \"N\", \"cod\": \"Y\", \"is_oda\": \"N\", \"sort_code\": \"GB\", \"state_code\": \"UP\"}}]}";
String jsonExp = "$.delivery_codes";
JsonNode pincodes = JsonPath.read(jsonExp, jsonString, JsonNode.class);
System.out.println("pincodesJson : "+pincodes);
上面的输出将是内部Json.
[{“postal_code”:{“district”:”Ghaziabad”,”pin”:201001,”pre_paid”:”Y”,”cash”:”Y”,”pickup”:”Y”,”repl”:”N”,”cod”:”Y”,”is_oda”:”N”,”sort_code”:”GB”,”state_code”:”UP”}}]
现在可以通过迭代我们上面得到的List(JsonNode)来解析每个单独的名称/值对.
for(int i = 0; i< pincodes.size();i++){
JsonNode node = pincodes.get(i);
String pin = JsonPath.read("$.postal_code.pin", node, String.class);
String district = JsonPath.read("$.postal_code.district", node, String.class);
System.out.println("pin :: " + pin + " district :: " + district );
}
输出将是:
pin :: 201001 district :: Ghaziabad
根据您尝试解析的Json,您可以决定是获取List还是仅获取单个String / Long值.
希望它有助于解决您的问题.