如何根据属性值过滤json的元素

时间:2019-02-14 10:51:13

标签: java json jackson jackson2

我有一个json模式,其中包含许多具有属性“ image”的元素。

unevaluatedProperties

和实际的json如下所示

  "passportPhoto": {
    "description": "Passport photo",
    "type": "string",
    "image": {
      "binaryEncoding": "base64"
    }
  },

是否有可能基于属性“图像”过滤架构并以jsonpath格式获取所有元素的列表

  "passportPhoto": "photo in base 64 encoded string format",

我必须使用json路径读取json,然后对照片进行一些处理,例如将其序列化。 但是我的问题是关于如何在Java系统中基于“图像”属性过滤模式

1 个答案:

答案 0 :(得分:1)

为此,您可以使用Jayway JsonPath库。它允许查找给定属性的路径。找到所有路径后,您可以为其提取值。描述JSON Schema的{​​{1}}也是有效的JSON,因此,首先,您可以从JSON中提取所有属性,然后在给定JSON Schema有效负载的情况下进行处理。在下面的示例中,我使用预定义的属性列表。

对于给定的JSON有效负载(假设所有JSON属性在模式中均以图片描述):

*photo

以下示例:

{
  "map": {
    "photo": "map photo"
  },
  "person": {
    "data": {
      "photos": {
        "photo": "photo Base64",
        "passportPhoto": "passport photo Base64"
      }
    }
  }
}

打印:

import com.jayway.jsonpath.EvaluationListener;
import com.jayway.jsonpath.JsonPath;
import com.jayway.jsonpath.ReadContext;

import java.io.File;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

public class JsonPathApp {
    public static void main(String[] args) throws Exception {
        File jsonFile = new File("./resource/test.json").getAbsoluteFile();

        List<String> paths = new ArrayList<>();
        ReadContext findPathsContext = JsonPath.parse(jsonFile).withListeners((found) -> {
            paths.add(found.path());
            return EvaluationListener.EvaluationContinuation.CONTINUE;
        });

        List<String> properties = Arrays.asList("photo", "passportPhoto");
        properties.forEach(p -> findPathsContext.read("$.." + p));

        ReadContext readContext = JsonPath.parse(jsonFile);

        for (String path : paths) {
            System.out.println("Path: " + path);
            System.out.println("Value: " + readContext.read(path));
        }
    }
}

另请参阅:

  1. Jsonpath with Jackson or Gson
  2. Json Path Maven