API 设计:让牛懂琴

2012-08-26 01:53

API 设计:让牛懂琴

by sofish

at 2012-08-25 17:53:26

original http://sofish.de/2100

对于 API 设计,这个演示稿讲得实存是太赞了,等不及的同学马上了解一下《RESTful API Design, Second Edition》的这 107 页吧。如果希望先听我讲讲 10 分钟收获的同学,可以先看下面的描述。

RESTful API Design, Second Edition from Apigee


以为需要买本书,看完整本才能明白什么是好的接口。没想到,利用 HTTP Verbs 和 URL,可以这样做非常简洁的 API。“对牛弹琴”被用以描述做无效劳动,可见弹琴者几乎做的都是无用功,而作者以深入浅出的方式让牛听懂琴变成了 — 甚至像我这样的牛 — 在 10 分钟之内立马理解。其主要需要注意的点可以归纳为以下几句:

保持 RESTful。只需 2 种 URL。不使用动词。使用复数名词。具体优于抽象。提供 JSON 的原则是支持 JS 调用。把复杂的参数放于 ? 号后面。借鉴优秀的 API。提供异常描述。提供库或者 SDK。

这里面值得强调,或者说可能需要一点解析的是这几点:

一、只需 2 种 URL

结合 HTTP Verbs,我们通常只需要 2 种 URL,一种用于集合的调用,一种用于单个实例的调用:

  • /dogs :用于调用狗狗列表
  • /dogs/1234 用于调用 dogs 这个列表中 ID 为 1234 的小狗

所有 API 都一样。其实我想你想到的可能是这样的形式,因为毕竟会需要有四种动作:创建 / 查看 / 修改 / 删除

  • /dogs [GET] 查看狗狗列表
  • /dogs/edit [PUT] 批量修改
  • /dogs/delete [DELETE] 批量删除
  • /dogs/1234 [GET] 查看 ID 为 1234 的小狗
  • /dogs/1234/edit [PUT] 对小狗做点什么
  • /dogs/1234/delete [DELETE] 删除小狗的存在

看起来不错。或者还可以变成 /dogCreate 之类的来减少一层,但还是不能实质上减少数目。这时太多接口总是导致记错,并且还需要记得 HTTP Verbs 与 URL 的对应。代码层面上也比较难做(或者应该对比下后面的实现)。何不考虑与 HTTP Verbs 结合:

  • POST –> Create 创新
  • GET –> Read 查看
  • PUT –> Update 修改
  • DELETE –> Delete 删除

这个时候我们只需要 2 种 URL,与 HTTP Verbs 充分结合:

POST GET PUT DELETE
/dogs 创建 查看列表 批量修改 删除所有
/dogs/1234 error 查看单个实例 修改单个实例 删除单个实例

 二、提供 JSON 的原则是支持 JS 调用

这点似乎一点难理解,先让我们来看一下几个设计吧:

// twitter
"created_at": "Thu Nov 03 05:19:38 +0000 2011"

//bing
"DateTime": "2011-10-29T09:35:00Z"

//Foursquare
"createdAt": 1320296464

这里假设我们有两种需要,一种是直接放入页面显示,一种是做计时器用,那么当我们拥有的两个变量,在 bing 和 4sq 上是这样的:

var obj = JSON.parse(response);

// bing
var stamp = obj.DateTime; // 返回 2011-10-29T09:35:00Z
// 显示出来也看得出是一个日期
// 但不能做计数器用,需要转换,这种格式 JS 还不好转

// 4sq
var stamp = obj.createdAt; // 返回 
// 显示出来需要用 JS 转 1320296464,因为是秒数,可以方便转成各种格式
// 可直接用于计数

显然,这种方式更灵活。API 最好支持 JS 直接调用/使用。

三、把复杂的变量放在 URL 参数上

这个如上面第一点所提到的,层级导致代码的难度增大,不如放成参数;这样还可以保证 API 接口的简洁和少量,而实现同样多的功能。

然后,或者你会像我一样,再一次阅读。然后去迭代/优化你的 API。