如何分离包含特定JSON数组的JSON值

时间:2019-02-08 07:25:05

标签: java json arraylist

我需要获取依赖项JSON数组的fileName值,并将其放入单独的数组(如Java列表)中。如果每个JSON数组对象都包含一个称为“漏洞”的JSON数组,则将其与“ fileName”,“ cvssScore”和“ severity”一起放入另一个列表或JSON对象中 这是JSON对象。这是一个很大的JSON,所以我上传到了云端硬盘

https://drive.google.com/open?id=1puZRU4XY5loLBnBqo2NvKajj_dBR7Ol7

我可以像下面这样直接获得特定的值。

String jsonFile = "C:\\Users\\Dexter\\IdeaProjects\\autoupgrader\\target\\dependency-check-report.json";
BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(jsonFile)));

JSONTokener tokener = new JSONTokener(br);
JSONObject object = new JSONObject(tokener);
JSONArray ja = object.getJSONArray("dependencies");
JSONObject jo = ja.getJSONObject(0);
JSONObject jo2 = jo.getJSONObject("evidenceCollected");
JSONArray ja2 = jo2.getJSONArray("versionEvidence");
JSONObject jo3 = ja2.getJSONObject(0);
System.out.println(jo3.getString("value"));

然后我试图通过将其转换为arraylist来获得,但是我找不到解决它的方法。

List <JSONObject> list = new ArrayList<>();
for (int i=0; i<ja.length(); i++){
    list.add(ja.getJSONObject(i));
}

System.out.println(Arrays.toString(list.toArray()));

1 个答案:

答案 0 :(得分:0)

要生成初始列表,可以使用已有的循环,也可以使用Java Stream API:

List<JSONObject> items = StreamSupport.stream(dependencies.spliterator(), false).map(d -> (JSONObject) d)
        .collect(Collectors.toList());

通过这种方式,您可以轻松过滤出所有包含关键“漏洞”的对象:

List<JSONObject> items = StreamSupport.stream(dependencies.spliterator(), false).map(d -> (JSONObject) d)
        .filter(o -> o.has("vulnerabilities"))
        .collect(Collectors.toList());

要生成第二个列表,其中包含所有易受攻击的文件及其文件名,cvssScore和严重性,您可以扩展上一个示例:

List<JSONObject> items = StreamSupport.stream(dependencies.spliterator(), false).map(d -> (JSONObject) d)
        .filter(o -> o.has("vulnerabilities"))
        .flatMap(o -> StreamSupport.stream(o.getJSONArray("vulnerabilities").spliterator(), false)
                .map(d -> (JSONObject) d)
                .map(v -> {
                    JSONObject j = new JSONObject();
                    j.put("fileName", o.getString("fileName"));
                    j.put("cvssScore", v.getString("cvssScore"));
                    j.put("severity", v.getString("severity"));
                    return j;
                }))
        .collect(Collectors.toList());

此操作的结果是JSON对象的列表。您可以轻松调整输出,或者根据需要添加更多属性。