在json文件中查找预定义模式属性的最佳方法

时间:2016-11-23 08:05:06

标签: java json jackson jsonschema

我有一个json模式文件,它遵循我创建的自定义规则。此架构文件是有效的json文件。它遵循以下模式。

 {
    "name":   {
                "fname" :  {
                             "displayName":"FirstName",
                             "dataType":"String"
                           }
                "lname"  : {
                             "displayName":"LastName",
                             "dataType":"String"
                           }
               },
    "address": {
                   "displayName":"Address",
                   "dataType":"String"
               }
  }

所以根据模式我需要用相应的值创建下面的json。

  {
       "name": {
                 "FirstName": "test",
                 "LastName" : "test1"
               },
       "Address" : "someAddress"
  }

因此,当我获得架构时,找到配置信息节点的最佳方法是什么?这是具有displayName和dataType参数的叶节点。目前我正在使用Jackson json遍历此树并使用displayName和dataType键查找节点。因为我无法准确地说出这个叶节点可能存在于哪个级别。是否有更好的方法来处理这种情况,而不是遍历整个json树寻找元素?

1 个答案:

答案 0 :(得分:1)

我不确定wnat是否完全是必需的(你想要fname对象或其属性的值),但是,JsonPath似乎很适合这里。它相当于json的xpath - 基于各种标准的搜索层次模型

我制作了一个小型演示来帮助您入门。您只需要查询查询字符串以满足您的要求。您可以使用Jayway JsonPath Evaluator作为REPL

import java.nio.file.*;
import com.jayway.jsonpath.*;
public class JsonPathDemo
{
    public static void main(String[] args)
    {
        // query: get all json objects that have displayName and dataType properties
        String jsonPathQuery = "$..*[?(@.displayName && @.dataType)]";
        try {
            String content = new String(Files.readAllBytes(Paths.get("C://temp/xx.json")));
            Object parsedContent = Configuration.defaultConfiguration().jsonProvider().parse(content);
            Object configElements = JsonPath.read(parsedContent, jsonPathQuery);
            System.out.println(configElements.getClass());
            System.out.println(configElements);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
} 

输出

class net.minidev.json.JSONArray
[{"displayName":"Address","dataType":"String"},{"displayName":"FirstName","dataType":"String"},{"displayName":"LastName","dataType":"String"}]

编辑:在评论中回答问题:

可以使用json-path-assert检查路径是否存在(并进行各种其他断言):

import static com.jayway.jsonpath.matchers.JsonPathMatchers.*;

// query for specific path 
String jsonSpecificPathQuery = "$..name.fname.displayName";

String content = new String(Files.readAllBytes(Paths.get("C://temp/xx.json")));
Object parsedContent = Configuration.defaultConfiguration().jsonProvider().parse(content);
System.out.println("hasJsonPath? " + hasJsonPath(jsonSpecificPathQuery).matches(parsedContent));