REST APIs 旨在通过HTTP 的动作语义METHOD, 以替代各种传统CRUD 操作所带来的命名问题,例如 "/userAdd"、"/userDelete"、"/userUpdate"、"/userGet"。 REST API 使得你可以仅通过 "/user" + METHOD 替代上述不同的路由。

使用以下提供的信息以帮助确定何种Method,以应用不同场景:

1.HTTP GET

使用 GET 请求获取资源信息 - 且不要以任何方式修改资源,因为 GET 请求不提倡修改资源状态,由此也被称为safe methods。

此外,GET APIs 应该是等幂的。 即除非其他的 API (POST or PUT) 修改了服务器资源状态,任何时候发送多次完全相同的 GET 请求应当返回完全相同的数据。

1.1 GET API 响应码#Response Codes

  • 对于任何给定的 HTTP GET API。 如果能在服务器上找到相应的资源,都必须返回 code 200(ok) -以及 response body. 通常根据平台实现,返回 xml 或者 json 内容。

  • 万一在服务器上没有找到资源,则API 必须返回 HTTP response code 404 (NOT FOUND)

  • 如果检测到 GET 请求本身是错误的,服务器应当返回 HTTP response code 400 (BAD REQUEST)

1.2 示例URIs

HTTP GET http://www/appdomin.com/users
HTTP GET http://www/appdomin.com/users?size=20&page=5
HTTP GET http://www/appdomin.com/users/123
HTTP GET http://www/appdomin.com/users/123/address

2. HTTP POST

POST APIs 用以创建新的子级资源,例如:某个目录下的子文件,又或者某个 数据库表的新增行。

当谈及 REST。 POST 方法是用于 给某个集合资源对象 创建一个新的资源

除非 响应包含了适当的 Cache-Control或者 Expires 头字段,该METHOD 的想用是不能够被缓存的。

请注意,POST 请求,既不 安全,也不幂等。 并且 调用两次完全相同的 POST 请求将会导致产生包含除了id,其他完全相同信息的两个不同的资源。

2.1 POST API Response Codes

  • 理想情况下,如果一个资源已经在服务器上创建过了, 那么响应应该是: HTTP response code 201(Created), 且包含 1. 描述请求状态和引用新资源的实体;2.一个 Location 头。

  • 很多时候,POST 方法执行的操作可能返回了一个不能被URI 所标识的资源。 在这种情况下,也应该响应 HTTP response code 200(OK) 或者 204(No Content) 。

2.2 示例 URIs

HTTP POST http://www/appdomin.com/users
HTTP POST http://www/appdomin.com/users/123/accounts

3. HTTP PUT

PUT APIs 主要是用于 更新一个既存的资源(如果这个资源不存在,则该API也可以选择要不要创建一个新的资源)

如果这个请求 通过了一个缓存, 并且 request-uri 标识了一个或多个当前缓存的实体,那么这些条目应当被视作过时的。 PUT 方法的响应式不可缓存的

3.1 PUT API Response Codes

  • 如果已经有一个被 PUT API 创建的新资源, 那么服务必须返回 HTTP response code 201(Created) 响应。

  • 如果一个存在的资源被修改了, 那么服务器应该返回 200 (OK) 或者 204 (No Content) 响应状态码,以告知请求成功完成。

示例 URIs

HTTP PUT http://www/appdomin.com/users/123
HTTP PUT http://www/appdomin.com/users/123/accounts/456

[POST 和 PUT APIs 的区别(https://restfulapi.net/rest-put-vs-post/) 能够从请求 URIs 观察一二: POST 请求是针对资源集合

对象发出的, 而 PUT 请求则是针对单个资源。

4. HTTP DELETE

顾名思义,DELETE APIs 用于删除资源(由请求 URI 标识)。

DELETE 操作是等幂的,如果你DELETE一个资源,那么它会从资源集合中移除掉目标

有些人可能认为这使得DELETE方法是非幂等的。这是讨论和个人意见的问题。

如果这个请求 通过了一个缓存, 并且 request-uri 标识了一个或多个当前缓存的实体,那么这些条目应当被视作过时的。 DELETE 方法的响应式不可缓存的

4.1 DELETE API Response Codes

  • 如果想用包含了状态描述的实体#If the response includes an rntity describing the status,一个 DELETE 请求的成功响应,应该是 HTTP response code 200(OK)

  • 如果该操作处于等待队列中,那么应该返回 202 (Accepted) 。

  • 如果操作已经执行,但是响应无实体,那么返回状态码应该是 204 (No Content)。

  • 对同个资源重复操作 DELETE API将不会改变输出 —— 然而, 当对一个 资源执行第二次操作的时候一般会返回 404(NOT FOUND) 应为它已经被删除掉了。

4.2 示例 URIs

HTTP DELETE http://www.appdomin.com/users/123
HTTP DELETE http://www.appdomain.com/users/123/accouts/456

5. HTTP PATCH

HTTP PATCH 请求被用于对一个资源进行部分更新 #to make a partial update

如果你看到一个PUT 请求也在修改一个资源实体,那么让它更加精确 —— PATCH METHOD 就是正确的选择专用于部分更新一个既存资源。 并且。你应该仅在需要替换某个资源的时候使用 PUT 请求。

请注意,如果你决定在你的应用中使用 PATCH APIs,也有一些挑战需要注意:

浏览器,服务器,以及web应用框架对PATCH 的支持并不是统一的, IE8,PHP, Tomcat. Django 等等都对 PATCH 不支持或者缺乏支持。

PATCH 请求的 payload#载荷 并不像 PUT 请求那样简单,例如:

HTTP GET /user/1

产生如下响应:

{ "id": 1, "username": "admin", "email": "email@example.org" }

一个简单的PATCH 请求以更新email将会像下面这样:

HTTP PATCH /users/1
[{ "op": "replace", "path":"/email", "value": "new.email@example.org" }]

根据以下 HTTP 规范,可能会有以下操作:

[
{ "op": "test", "path": "/a/b/c", "value": "foo" },
{ "op": "remove", "path": "/a/b/c" },
{ "op": "add", "path": "/a/b/c", "value": [ "foo", "bar"] },
{ "op": "replace", "path": "/a/b/c", "value": 42 },
{ "op": "move", "from": "/a/b/c", "path": "/a/b/c" },
{ "op": "copy", "from": "/a/b/c", "path": "/a/b/c" },
]

PATCH Method 请不是 POST 或者 PUT Methods 的替代品,它不同于替换整个资源

6. HTTP Methods 总结

下表是上述讨论的HTTP methods 的使用总结

The below table summarises the use of HTTP methods discussed above.

HTTP Method CRUD Collection Resource (e.g. /users) Single Resouce (e.g. /users/123)
POST Create 201 (Created), ‘Location’ header with link to /users/{id} containing new ID Avoid using POST on a single resource
GET Read 200 (OK), list of users. Use pagination, sorting, and filtering to navigate big lists 200 (OK), single user. 404 (Not Found), if ID not found or invalid
PUT Update/Replace 405 (Method not allowed), unless you want to update every resource in the entire collection of resource 200 (OK) or 204 (No Content). Use 404 (Not Found), if ID is not found or invalid
PATCH Partial Update/Modify 405 (Method not allowed), unless you want to modify the collection itself 200 (OK) or 204 (No Content). Use 404 (Not Found), if ID is not found or invalid
DELETE Delete 405 (Method not allowed), unless you want to delete the whole collection — use with caution 200 (OK). 404 (Not Found), if ID not found or invalid

7.相关术语#Glossary

7.1 Safe Methods

如果 Methods 的语义化定义本质上是只读的,那么就被认为 Methods 是安全的。 客户端不会请求,也不会期望由于对目标资源应用安全方法而导致源服务器上的任何状态更改。

GET, HEAD, OPTIONS, TRACE methods 被认为是安全 methods, 就像每个 HTTP 定义的, GET 和 HEAD methods 应该仅被用于资源的获取,且不会更新/删除 服务器上的资源。

区分安全和非安全methods的目的在于,允许自动获取资源处理(如爬虫)获取数据,而不用担心造成损害。

安全methods 允许用户代理#agents 其他methods,例如 POST, PUT, DELETE. 以这种独特的方式,使用户意识到可能正在要求采取不安全操作的事实 - 他们可以在服务器上更新/删除资源,因此应仔细使用。

7.2 Idempotent Methods #幂等方法

如果一次和多次操作所造成的结果均相同,这就是幂等这个词的含义。

在HTTP 中, PUT, DELETE 以及上述的safy methods (GET, HEAD, OPTIONS, TRACE) 都是幂等操作

translate @from resuful api

REST APIs的更多相关文章

  1. (转载)构建public APIs与CORS

    from: https://segmentfault.com/a/1190000000709909 理由:在操作层面详细的讲解了跨域的操作.尤其是对于option请求的详解.收藏. 在构建Public ...

  2. ECMAScript Web APIs node.js

    https://hacks.mozilla.org/2015/04/es6-in-depth-an-introduction/ What falls under the scope of ECMASc ...

  3. 【墙内备份】Android 6.0 APIs

    Android 6.0 APIs In this documentSHOW MORE Fingerprint Authentication Confirm Credential App Linking ...

  4. swagger:The World's Most Popular Framework for APIs.

    swagger官网:http://swagger.io/ swagger ui demo:http://petstore.swagger.io 让API文档总是与API定义同步更新,是一件非常有价值的 ...

  5. [译]Node.js : Building RESTful APIs using Loopback and MySQL

    国庆后可能就要使用StrongLoop那套东西来做项目了 原文:http://www.javabeat.net/loopback-mysql/ Loopback是什么? Loopback是一个开源的N ...

  6. URLRedirector 解决网页上无法访问 google CDN 的问题(fonts、ajax、themes、apis等)

    URLRedirector 解决网页上无法访问 google CDN 的问题(fonts.ajax.themes.apis等) 由于某些原因,在访问国外的网站时有时候会特别慢,像 stackoverf ...

  7. 谷歌正式发布Google APIs Client Library for .NET

    好消息,特大好消息! 英文原文:Google API library for .NET paves the way for Google services on Windows phone 本月 17 ...

  8. POSTMAN and HTTPie to test APIs

    http://blog.mashape.com/postman-httpie-test-apis/ We love working with APIs at Mashape, and we love ...

  9. Android SDK Manager Google Apis 下载

    本意是想利用google的gcm来实装android推送功能的,很遗憾, google貌似已经停止提供啥服务给国内了,或者说国内想继续使用google 服务暂时变得几乎不可能了.找了个代理来进行goo ...

  10. Improve Scalability With New Thread Pool APIs

    Pooled Threads Improve Scalability With New Thread Pool APIs Robert Saccone Portions of this article ...

随机推荐

  1. RocketMQ实现分布式事务

    相关文章:http://www.uml.org.cn/zjjs/201810091.asp(深入理解分布式事务,高并发下分布式事务的解决方案) 三种分布式事务: 1.基于XA协议的两阶段提交 2.消息 ...

  2. spring @Bean和@Order 官方doc理解

    今天阅读了spring的官方代码,(大概)理解了@Bean和@Order如何使用. @Bean 官方代码解读: 0.@Bean的注入,用于表示这个bean被spring容器管理(创建.销毁)(官方英文 ...

  3. 学习 Haproxy (二)

    1. Haproxy介绍 Haproxy是一个开源的高性能的反向代理或者说是负载均衡服务软件之一,它支持双机热备.虚拟主机.基于TCP和HTTP应用代理等功能.其配置简单,而且拥有很好的对服务器节点的 ...

  4. SCTF 2018_Simple PHP Web

    SCTF 2018_Simple PHP Web 进入环境注意观察url http://www.bmzclub.cn:23627/?f=login.php 有点像是文件读取我们尝试读一下/etc/pa ...

  5. 从零开始画自己的DAG作业依赖图(四)--节点连线优化版

    概述 上个版本简单的连线在一些复杂场景,尤其层级比较多,连线跨层级比较多的情况下,会出现线条会穿过矩形的情况,这一讲就是在这个基础上,去优化这个连线. 场景分析 在下面几种情况下,简单版本的画法已经没 ...

  6. Nuxt.js的踩坑指南(常见问题汇总)

    本文会不定期更新在nuxt.js中遇到的问题进行汇总.转发请注明出处,尊重作者,谢谢! 强烈推荐作者文档版踩坑指南,点击跳转踩坑指南 在Nuxt的官方文档中,中文文档和英文文档都存在着不小的差异. 1 ...

  7. 块级格式化上下文(BFC)

    一.什么是BFC 具有BFC属性的元素也属于普通流定位方式,与普通容器没有什么区别,但是在功能上,具有BFC的元素可以看做是隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素,并且具有普通容 ...

  8. 大数据学习之路又之从小白到用sqoop导出数据

    写这篇文章的目的是总结自己学习大数据的经验,以为自己走了很多弯路,从迷茫到清晰,真的花费了很多时间,希望这篇文章能帮助到后面学习的人. 一.配置思路 安装linux虚拟机--->创建三台虚拟机- ...

  9. ubantu14.04搜狗拼音安装

    1. 先卸载fcitx: sudo apt-get purge fcitx*2. 安装fcitx和libssh2-1: sudo apt-get install fcitx 和 sudo apt-ge ...

  10. jboss修改内存

    在修改配置文件,在 <JBOSS_HOME> /bin/stadalone.conf中      找到并修改  如图