多条件查询遵循 Restful API 规范的改如何设计?

问题描述

  1. 由于遵循 Restful API 规范,Get 请求的方式针对于多条件查询来说,不好设计接口

问题出现的环境背景及自己尝试过哪些方法

有人提供过两种方式

  1. http://localhost:8080/app/names?queryDtoStr={"query1":12,"query2":2,"query3":2}
  2. 或者直接使用 POST 请求

相关代码

你期待的结果是什么?实际看到的错误信息又是什么?

有没有其他设计方式,尽量遵循 Restful API 规范

阅读 6.6k
2 个回答

引用于:RESTful API 设计最佳实践
原文:Best Practices for Designing a Pragmatic RESTful API

如果Action不符合CRUD操作那该怎么办?

  1. 重新构造这个Action,使得它像一个资源的field(我理解为部分域或者部分字段)。这种方法在Action不包含参数的情况下可以奏效。例如一个有效的action可以映射成布尔类型field,并且可以通过PATCH更新资源。
  2. 利用RESTful原则像处理子资源一样处理它。例如,Github的API让你通过PUT /gists/:id/star 来 star a gist ,而通过DELETE /gists/:id/star来进行 unstar 。
  3. 有时候你实在是没有办法将Action映射到任何有意义的RESTful结构。例如,多资源搜索没办法真正地映射到任何一个资源接入点。这种情况,/search 将非常有意义,虽然它不是一个名词。这样做没有问题 - 你只需要从API消费者的角度做正确的事,并确保所做的一切都用文档清晰记录下来了以避免(API消费者的)困惑。

所以题主完全可以提供 /app/names/search 服务专门用于搜索功能,查询参数一般是通过 query parameters 的方式传递。

Restful查询就用Get请求,参数传递就用query string了,当然要考虑你的参数的大小,毕竟Get传参,参数内容有限。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题