REST API URI 的七大设计原则

本贴最后更新于 2704 天前,其中的信息可能已经时移世异

原文:http://blog.restcase.com/7-rules-for-rest-api-uri-design/
作者:Guy Levin
翻译:Aladdin

在了解 REST API URI 设计的规则之前,让我们快速浏览一些我们将要讨论的术语。

URIs

REST API 使用统一资源标识符(URI)来寻址资源。在当今互联网上,充斥着各种各样的 URI 设计规则,既有像//api.example.com/louvre/leonardo-da-vinci/mona-lisa 这样能够清楚的传达 API 资源模型的文章,也有很难理解的文章,例如://api.example.com/68dd0-a9d3-11e0-9f1c-0800200c9a66 ;Tim Berners-Lee 在他的“Axioms of Web Architecture”一文中将 URI 的不透明度总结成一句话:

唯一可以使用标识符的是引用对象。在不取消引用时,就不应该查看 URI 字符串的内容以获取其他信息。
——蒂姆·伯纳斯 - 李

客户端必须遵循 Web 的链接范例,将 URI 视为不透明标识符。

REST API 设计人员应该在考虑将 REST API 资源模型传达给潜在的客户端开发者的前提下,创造 URI。在这篇文章中,我将尝试为 REST API URI 引入一套设计规则

先跳过规则,URI 的通用语法也适用与本文中的 URI。RFC 3986 定义了通用 URI 语法,如下所示:

URI = scheme “://” authority “/” path [ “?” query ][ “#” fragment ]

规则 1:URI 结尾不应包含(/)

这是作为 URI 路径中处理中最重要的规则之一,正斜杠(/)不会增加语义值,且可能导致混淆。REST API 不允许一个尾部的斜杠,不应该将它们包含在提供给客户端的链接的结尾处。

许多 Web 组件和框架将平等对待以下两个 URI:
http://api.canvas.com/shapes/
http://api.canvas.com/shapes

但是,实际上 URI 中的每个字符都会计入资源的唯一身份的识别中。

两个不同的 URI 映射到两个不同的资源。如果 URI 不同,那么资源也是如此,反之亦然。因此,REST API 必须生成和传递精确的 URI,不能容忍任何的客户端尝试不精确的资源定位。

有些 API 碰到这种情况,可能设计为让客户端重定向到相应没有尾斜杠的 URI(也有可能会返回 301 - 用来资源重定向)。

规则 2:正斜杠分隔符(/)必须用来指示层级关系

URI 的路径中的正斜杠(/)字符用于指示资源之间的层次关系。

例如:
http://api.canvas.com/shapes/polygons/quadrilaterals/squares;

规则 3:应使用连字符( - )来提高 URI 的可读性

为了使您的 URI 容易让人们理解,请使用连字符( - )字符来提高长路径中名称的可读性。在路径中,应该使用连字符代空格连接两个单词 。

例如:
http://api.example.com/blogs/guy-levin/posts/this-is-my-first-post

规则 4:不得在 URI 中使用下划线(_)

一些文本查看器为了区分强调 URI,常常会在 URI 下加上下划线。这样下划线(_)字符可能被文本查看器中默认的下划线部分地遮蔽或完全隐藏。

为避免这种混淆,请使用连字符( - )而不是下划线

规则 5:URI 路径中首选小写字母

方便时,URI 路径中首选小写字母,因为大写字母有时会导致一些问题。RFC 3986 将 URI 定义为区分大小写,但 scheme 和 host components 除外。

例如:
http://api.example.com/my-folder/my-doc

HTTP://API.EXAMPLE.COM/my-folder/my-doc
这个 URI 很好。URI 格式规范(RFC 3986)认为该 URI 与 URI#1 相同。

http://api.example.com/My-Folder/my-doc
而这个 URI 与 URI 1 和 2 不同,这可能会导致不必要的混淆。

规则 6:文件扩展名不应包含在 URI 中

在 Web 上,(.)字符通常用于分隔 URI 的文件名和扩展名。
REST API 不应在 URI 中包含人造文件扩展名,来指示邮件实体的格式。相反,他们应该依赖通过 Content-Type 中的 header 传递 media type,来确定如何处理正文的内容。

http://api.college.com/students/3248234/courses/2005/fall.json
http://api.college.com/students/3248234/courses/2005/fall

如上所示:不应使用文件扩展名来表示格式。

应鼓励 REST API 客户端使用 HTTP 提供的格式选择机制 Accept request header。

为了是链接和调试更简单,REST API 应该支持通过查询参数来支持媒体类型的选择。

规则 7:端点名称是单数还是复数?

keep-it-simple 的原则在这里同样适用。虽然一些”语法学家”会告诉你使用复数来描述资源的单个实例是错误的,但实际上为了保持 URI 格式的一致性建议使用复数形式。

本着 API 提供商更容易实施和 API 使用者更容易操作的原则,可以不必纠结一些奇怪的复数(person/people,goose/geese)。

但是应该怎么处理层级关系呢?如果一个关系只能存在于另一个资源中,RESTful 原则就会提供有用的指导。我们来看一下这个例子。学生有一些课程。这些课程在逻辑上映射到学生终端,如下所示:

http://api.college.com/students/3248234/courses - 检索 id 为 3248234 的学生学习的所有课程的清单。
http://api.college.com/students/3248234/courses/physics -检索该学生的物理课程

结论

当你在设计 REST API 服务时,您必须注意这些由 URI 定义的资源。

正在构建的服务中的每个资源将至少有一个 URI 标识它。这个 URI 最好是有意义的,且能充分描述资源。URI 应遵循可预测的层次结构,用来提高其可理解性,可用性:可预测的意义在于它们是一致的,它的层次结构在数据关系上是有意义的。

RESTful API 是为使用者编写的。URI 的名称和结构应该能够向使用者传达更清晰的含义。通过遵循上述规则,您将创建一个更清晰的的 REST API 与更友好的客户端。这些并不是 REST 的规则或约束,仅仅是 API 的增强和补充。

我也建议你来看看 http://blog.restcase.com/5-basic-rest-api-design-guidelines/这篇文章。

最后,望大家牢记:你在为你的客户端设计 API URI,而不仅仅是为你的数据。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3453 回帖 • 203 关注
  • 技术

    到底什么才是技术呢?

    88 引用 • 179 回帖 • 4 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...