【问题标题】:How to separate JSON values which contains specific JSON array如何分隔包含特定 JSON 数组的 JSON 值
【发布时间】:2019-02-08 07:25:04
【问题描述】:

我需要获取依赖 JSON 数组的 fileName 值并将其放入单独的数组中(如 java 列表)。如果每个 JSON Array 对象包含名为“vulnerabilities”的 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()));

【问题讨论】:

    标签: java json arraylist


    【解决方案1】:

    要生成初始列表,您可以使用已有的循环,也可以使用 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 对象的列表。您可以轻松调整输出,或者根据需要添加更多属性。

    【讨论】:

      猜你喜欢
      • 2020-11-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-11-25
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-12-20
      相关资源
      最近更新 更多