为了账号安全,请及时绑定邮箱和手机立即绑定

关于 RESTful 风格接口一些小疑问

关于 RESTful 风格接口一些小疑问

鸿蒙传说 2018-10-23 22:01:00
写接口时候参考了restful风格,阮一峰 RESTful API 设计指南有如下例子GET /zoos:列出所有动物园 POST /zoos:新建一个动物园 GET /zoos/ID:获取某个指定动物园的信息 PUT /zoos/ID:更新某个指定动物园的信息(提供该动物园的全部信息) PATCH /zoos/ID:更新某个指定动物园的信息(提供该动物园的部分信息) DELETE /zoos/ID:删除某个动物园 GET /zoos/ID/animals:列出某个指定动物园的所有动物 DELETE /zoos/ID/animals/ID:删除某个指定动物园的指定动物但实际应用上,并没有这么简单,比如有接口:列出所有所有动物:path 是 /zoos/all/animals/all 还是 /animals,按接口目的来看,我只关心动物 /animals好像更合适,但与 /zoos/ID/animals 功能有重合,后台要维护两个路由列出有大熊猫动物园:path 怎么写,列出所有海洋动物园所有动物:path 怎么写,实际接口中筛选条件通常会很多,而且并不会像 国>省>市>区>路这样一级一级地缩小范围,这种情况下,传统方式写接口似乎就非常简单,getZoos?city=广州&anamal_type=大熊猫getZoos?zoo_type=海洋馆getAnimals?anamal_type=海洋生物接口初期,功能简单,用restful非常优雅,但是功能复杂起来了,觉得好像不太适用,而且接口版本也没达到经升级的程度,就会有两种写法并存,好尴尬!你们是怎么做的!有没有功能复杂一点的restful例子?
查看完整描述

1 回答

?
慕斯709654

TA贡献1840条经验 获得超5个赞

你也没必要非要在 /zoos/ID/animals/ID 这样写啊
不能有动词 不代表不让你用 参数啊 
也可以用一些参数进行过滤

POST /getZoos  
POST /saveZoos 
POST /removeZoos
get /zoos  
POST /zoos 
DELETE /zoos

例如,从账户1向账户2汇款500元 下面这样写肯定不行

POST /accounts/1/transfer/500/to/2

可以这样

POST /transaction  from=1&to=2&amount=500.00


查看完整回答
反对 回复 2018-10-23
  • 1 回答
  • 0 关注
  • 505 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信