肯定存在一种查询 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 区 :: Ghaziabad
根据您尝试解析的 Json,您可以决定是获取 List 还是仅获取单个 String/Long 值。
希望它有助于解决您的问题。