【发布时间】:2016-05-01 15:43:52
【问题描述】:
我的要求是实现高级搜索 Rest API 来搜索手机。搜索 API 的 URI 是 http://myservice/api/v1/phones/search?q=${query_expression}
其中q 是复杂的查询表达式。有以下问题
1) 由于高级搜索涉及冗长的查询表达式,URI 不适合 GET 调用。是否可以通过 POST 请求实现搜索 API 并仍然保持 RESTful 状态?
2) 我遇到了以下高级搜索的实现:
- 第一种方法 - 发送查询表达式的完整中缀表达式。 例如。
PHONENAME STARTSWITH 'AR' AND ( PHONETYPE = '4G' OR PHONECOLOR = 'RED')
-
第二种方法 - 以 json 的形式构建整个查询表达式。 例如。
{"criteria":[ {"index":1,"field":"PHONENAME","value":"AR","comparator":"STARTSWITH"}, {"index":2,"field":"PHONETYPE","value":"4G","comparator":"EQUALS"}, {"index":3,"field":"PHONECOLOR","value":"RED","comparator":"EQUALS"} ],"criteria":"( 1 AND (2 OR 3) )"} -
第三种方法 - 将查询表达式实现为 json 的替代方法。 例如。
{"and":[ {"field":"PHONENAME","value":"AR","comparator":"STARTSWITH"}, "or":[ {"field":"PHONETYPE","value":"4G","comparator":"EQUALS"}, {"field":"PHONECOLOR","value":"RED","comparator":"EQUALS"}] ]}
在这三种方法中,哪种方法更符合 RESTful 标准?欢迎提出任何其他方法的建议:)
【问题讨论】:
-
我认为,对带有参数的某些资源执行 GET 是 REST 所需要的。您指定为参数的内容对 REST 无关紧要(如果它不是 URI 或其他资源)。所以我会选择选项 1,或者类似的东西,在 URI 中易于阅读。