关于接口设计的问题

发布于 2022-09-11 22:18:03 字数 403 浏览 22 评论 0

有一个商品信息的接口:
api/goods/<goods_id>/

每个商品都有一条关联的追溯信息(与商品主键关联),对于追溯信息的接口应该怎么设计比较好?
我想到的情况:

  1. 第一种:api/tracebacks/?goods=<goods_id>

    这种写法我是用过的,但是感觉语义不明确,每个商品的追溯信息有且仅有一条的,使用查询多条数据的接口形式,感觉很不合适
  2. 第二种:api/goods/<goods_id>/traceback/

    这种不知道是否规范

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

故事未完 2022-09-18 22:18:03

看实际的情况。

第一种应该是/api/traceback?good=<good_id>
当有一个traceback集中化的系统,以此为中心时,可以使用这种方式。good作为查询条件,以后还能扩展其他查询条件。

第二种/api/good/<good_id>/traceback
如果只是针对每个goodtrackback,那么应当使用这种形式。

其他的形式

/api/traceback/good/<good_id>
此种情况和第一种类似,但只能查询单条件。当然,可以扩展成/api/traceback/good/<good_id>/order/<order_id>这样的,但是从语义上就有资源重要性的先后关系。


插一句,单条资源应该都是单数形式,如good;只有列表时才用复数,如/api/goods

帅冕 2022-09-18 22:18:03

api/tracebacks/goods/<goods_id>

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文