编程语言
首页 > 编程语言> > 将动态JSON值解析为Java对象

将动态JSON值解析为Java对象

作者:互联网

在我的应用程序中,我有很多具有排序和过滤功能的概述(表格).并且因为不同的列可以容纳不同的值类型(字符串,数字,日期,集合等),这些列的过滤器也可以带来不同的值.让我向您展示一些示例(已转换为JSON,因为已通过REST请求发送到服务器):

对于简单的字符串值,它就像:

{"<column_name>":"<value>"}

对于数字和日期列,过滤器如下所示:

{"<column_name>":[{"operator":"eq","value":"<value>"}]}
{"<column_name>":[{"operator":"eq","value":"<value1>"},{"operator":"gt","value":"<value2>"}]}

对于设置过滤器看起来像

{"<column_name>":["<value1>","<value2>"(,...)]}

现在我需要在一个将构建SQL查询的WHERE子句的辅助类中解析该JSON.在PHP中这不是问题,因为我可以调用json_decode,然后简单地检查一些值是数组,字符串还是其他任何东西……但是如何在Java中简单地执行此操作?

到目前为止,我使用的是Spring的JsonJsonParser(我没有发现像Jackson,Gson和其他人一样使用Spring的不同解析器之间有任何明显的区别).

我正在考虑使用三种不同的构造函数创建一个自己的数据对象类,或者为这三种可能性创建三个数据对象类,但是我不知道在解析器解析JSON之后如何处理为column_name返回的值. ..

简单地看一下这些例子,它给了我三种可能性:

> Map< String,String>
> Map< String,Map< String,String>>
> Map< String,String []>

任何想法或线索?

解决方法:

您必须在运行时检查值的类型.您可以使用Map< String,Object>或者使用JsonNode.

Map< String,Object>

JsonParser parser = JsonParserFactory.getJsonParser();
Map<String, Object> map = parser.parseMap(str);
Object filterValue = filter.get("<column_name>");
if (filterValue instanceof String) {
  // str is like "{\"<column_name>\":\"<value>\"}"
} else if (filterValue instanceof Collection) {
  for (Object arrayValue : (Collection<Object>) filterValue) {
    if (arrayValue instanceof String) {
      // str is like "{\"<column_name>\":[\"<value1>\",\"<value2>\"]}"
    } else if (arrayValue instanceof Map) {
      // str is like "{\"<column_name>\":[{\"operator\":\"eq\",\"value\":\"<value>\"}]}"
    }
  }
}

JsonNode

ObjectMapper mapper = new ObjectMapper();
JsonNode filter = mapper.readTree(str);
JsonNode filterValue = filter.get("<column_name>");
if (filterValue.isTextual()) {
  // str is like "{\"<column_name>\":\"<value>\"}"
} else if (filterValue.isArray()) {
  for (JsonNode arrayValue : filterValue.elements()) {
    if (arrayValue.isTextual()) {
      // str is like "{\"<column_name>\":[\"<value1>\",\"<value2>\"]}"
    } else if (arrayValue.isObject()) {
      // str is like "{\"<column_name>\":[{\"operator\":\"eq\",\"value\":\"<value>\"}]}"
    }
  }
}

标签:json,java,spring,spring-boot-2,json-deserialization
来源: https://codeday.me/bug/20190623/1272254.html