【发布时间】:2015-09-22 15:59:36
【问题描述】:
在我的应用程序中,我有很多带有排序和过滤功能的概览(表格)。并且因为不同的列可以保存不同的值类型(字符串、数字、日期、集合等),这些列的过滤器也可以带来不同的值。让我向您展示几个示例(已转换为 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>"(,...)]}
现在我需要在一个帮助类中解析该 JSON,该类将构建 SQL 查询的 WHERE 子句。在 PHP 中这不是问题,因为我可以调用 json_decode,然后简单地检查某个值是否为 array、string 或其他任何值...但是如何在 Java 中简单地做到这一点?
到目前为止,我使用的是 Spring 的 JsonJsonParser(我没有发现 Spring 附带的不同解析器之间有任何明显的差异,例如 Jackson、Gson 等)。
我正在考虑使用三个不同的构造函数创建一个自己的数据对象类,或者为所有三种可能性创建三个数据对象类,但我不知道如何处理返回的 值对于column_name解析器解析JSON后...
只看例子,它给了我三种可能性:
Map<String, String>Map<String, Map<String, String>>Map<String, String[]>
有什么想法或线索吗?
【问题讨论】:
-
你能解释一下
JsonJsonParser是什么吗? -
@SotiriosDelimanolis 它是
org.springframework.boot.json包的一部分,由以下解析器组成:Basic、Gson、Jackson、Json、JsonSimple和Yaml(后缀为JsonParser获取全名,因此您将获得例如JsonJsonParser)。
标签: java json spring spring-boot json-deserialization