将动态JSON值解析为Java对象

偷偷摸摸的

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

对于简单的字符串值,它类似于:

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

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

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

对于设置,过滤器看起来像

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

现在,我需要在一个帮助器类中解析该JSON,该类将构建WHERESQL查询子句。在PHP中,这是不是我可以调用一个问题json_decode,然后简单地检查一些值是否arraystring或任何其他...但如何做到这一点只需在Java中?

到目前为止,我使用Spring的JsonJsonParser(我没找到不同的解析器之间,像春天来临的任何明显的差异JacksonGson以及其他)。

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

简单地看一下示例,它为我提供了三种可能性:

  1. Map<String, String>
  2. Map<String, Map<String, String>>
  3. 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>\"}]}"
    }
  }
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章