关于接口设计的问题
有一个商品信息的接口:api/goods/<goods_id>/
每个商品都有一条关联的追溯信息(与商品主键关联),对于追溯信息的接口应该怎么设计比较好?
我想到的情况:
第一种:
api/tracebacks/?goods=<goods_id>
这种写法我是用过的,但是感觉语义不明确,每个商品的追溯信息有且仅有一条的,使用查询多条数据的接口形式,感觉很不合适
第二种:
api/goods/<goods_id>/traceback/
这种不知道是否规范
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
看实际的情况。
第一种应该是
/api/traceback?good=<good_id>
。当有一个
traceback
集中化的系统,以此为中心时,可以使用这种方式。good
作为查询条件,以后还能扩展其他查询条件。第二种
/api/good/<good_id>/traceback
。如果只是针对每个
good
的trackback
,那么应当使用这种形式。其他的形式
/api/traceback/good/<good_id>
此种情况和第一种类似,但只能查询单条件。当然,可以扩展成
/api/traceback/good/<good_id>/order/<order_id>
这样的,但是从语义上就有资源重要性的先后关系。插一句,单条资源应该都是单数形式,如
good
;只有列表时才用复数,如/api/goods
。api/tracebacks/goods/<goods_id>