博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
非RESTful的微软REST API指南
阅读量:6173 次
发布时间:2019-06-21

本文共 1759 字,大约阅读时间需要 5 分钟。

微软发布了创建“RESTful” API的指南。Roy Fielding将这些与REST没有多大关系的API称为HTTP API。

\\

许多组织都发布了创建面向Web的HTTP API的建议,甚至是白宫都发布了一份标准——“”。近日,微软公开了他们的“”,这是一份全面而成熟的规范。该规范被制定出来,主要是供Azure团队在构建云服务时使用。

\\

下面总结了微软API指南的一些关键点,感兴趣地读者可以阅读完整的规范。

\\
  • 为了便于API的应用,URL应该是人类可读和可构造的,而不必借助客户端库。 \\
  • 应支持以下HTTP谓词:GET、PUT、DELETE、POST、HEAD、PATCH、OPTIONS。不是所有的资源都应该支持所有的谓词。 \\
  • GET、PUT、DELETE和HEAD应该是幂等的。 \\
  • 自定义头信息不是必须的。 \\
  • 客户端应该不需要在URL中传递个人身份信息参数,因为它们可能会暴露在日志文件中。参数应该通过头信息传递。 \\
  • 数据应该以流行的格式提供。 \\
  • 默认数据编码是JSON。 \\
  • “基本型数值必须遵循标准序列化成JSON。” \\
  • 使用API的开发人员应该能够使用喜欢的语言和平台。 \\
  • 即使是简单的HTTP工具,如curl,也应该能够访问服务。 \\
  • API应该支持显式版本。 \\
  • 服务应该保持稳定,如果可能,就不要引入破坏性修改,但如果必要,它们也应该允许这样做,通过增加版本号标识出来。 \\
  • 版本应该使用一种Major.Minor方案。 \\
  • 服务可以通过Web钩子(HTTP回调)实现推送通知。\

该指南提供了一个例子,说明了什么样的URL是结构良好的URL:

\\
https://api.contoso.com/v1.0/people/jdoe@contoso.com/inbox\
\\

而另外一个例子说明了什么样的URL是应该避免的:

\\
https://api.contoso.com/EWS/OData/Users('jdoe@microsoft.com')/Folders('…[very long identifier]…=')\
\\

Roy Fielding是REST及HTTP/1.1的作者,同时也是Apache基金会的联合创始人。在微软发布这份REST API指南之后不久,他就:“即使是我最糟糕的REST描述也比提供的总结或参考要好很多。”InfoQ联系了Fielding,更详细地了解他为什么对这份规范不满意。以下是他的完整回复:

\\
\

我认为,像微软这样的公司决定将部分内部文档和开发指南发布到公共论坛,尤其是像GitHub这样的开源协作空间,是很好的。对于公共对话的这种开放性将极大地改善我们这个行业的工作方式。

\\

对于这份指南,我不满意的是,这份指南明明是总结了如何在微软的生态系统中开发合理的HTTP API,但却冠以REST和RESTful API的标签。REST不等于HTTP,这是显而易见的,粗略地读下任何有关REST的资料就可以知道。这份指南明显不是基于REST的,他们甚至没有设法参考我的工作(除了已经被RFC7231废除的RFC2616的部分内容)。对于以前深入Web Services世界的人们,这是一个常见的错误:将REST描述成SOAP/RPC接口的某种HTTP版本。

\\

不管那种错误在实际中多么常见,它都不能自称是REST。REST架构风格的大部分属性都源于对其所有约束的坚持,而不只是那些与过去已失败的工具类似的约束。如果那些想要使用HTTP构建RPC接口的人们,将它们的接口称为HTTP API,那么我没有任何意见。它们不是REST的。它们不属于Web。那并不是说,它们不能被诚实地描述,并实现为HTTP服务。要这样理解它们,讨论它们的实现指南,而又不觉得需要遵从错误的说法,这是值得的。

\
\\

许多Web服务提供商都使用了HTTP API,并且运用得非常成功。大部分云计算都是基于这样的API。不知道为什么这么多人坚持把它们的服务称为“RESTful”,而它们并不是。关于这个问题,我们建议那些有兴趣了解更多信息的读者阅读下列InfoQ文章:《》、《》。

\\

查看英文原文

转载地址:http://xmqba.baihongyu.com/

你可能感兴趣的文章
本年度好技能
查看>>
iis6 php安装 (一)
查看>>
关于,在Mysql中,外键是否会影响性能的问题???
查看>>
利用javascript设置图片等比例缩小
查看>>
dedeCMS如何给频道页添加缩略图
查看>>
CoreSeek快速安装
查看>>
Linux 网络性能调试工具Netstat
查看>>
我的友情链接
查看>>
报表下载SSH
查看>>
我的友情链接
查看>>
Raid磁盘阵列真的是100%的安全吗?raid有哪些常见的故障?
查看>>
Raid5两块硬盘离线解决方案 -阵列数据恢复案例
查看>>
IBM AIX存储层结构介绍 / 常用命令整理
查看>>
sudo用法简记
查看>>
有关宏定义的一篇文章
查看>>
Kubernetes 基本概念
查看>>
Linux命令:ssh,scp使用及免密码登录
查看>>
我的友情链接
查看>>
在CentOS上编译安装Nginx+实验环境搭建+测试
查看>>
支持二次开发的Zigbee模块(SNAP技术)
查看>>