0. REST不是"rest"这个单词,而是几个单词缩写。;

1. REST描述的是在网络中client和server的一种交互形式;REST本身不实用,实用的是如何设计 RESTful API(REST风格的网络接口);

2. Server提供的RESTful API中,URL中只使用名词来指定资源,原则上不使用动词。"资源"是REST架构或者说整个网络处理的核心。比如:

http://api.qc.com/v1/newsfeed: 获取某人的新鲜;

http://api.qc.com/v1/friends: 获取某人的好友列表;

http://api.qc.com/v1/profile: 获取某人的详细信息;

3. 用HTTP协议里的动词来实现资源的添加,修改,删除等操作。即通过HTTP动词来实现资源的状态扭转:

GET 用来获取资源,

POST 用来新建资源(也可以用于更新资源),

PUT 用来更新资源,

DELETE 用来删除资源。

比如:

DELETE http://api.qc.com/v1/friends: 删除某人的好友 (在http parameter指定好友id)

POST http://api.qc.com/v1/friends: 添加好友

UPDATE http://api.qc.com/v1/profile: 更新个人资料

禁止使用: GET http://api.qc.com/v1/deleteFriend

如图:

4. Server和Client之间传递某资源的一个表现形式,比如用JSON,XML传输文本,或者用JPG,WebP传输图片等。当然还可以压缩HTTP传输时的数据(on-wire data compression)。

5. 用 HTTP Status Code传递Server的状态信息。比如最常用的 200 表示成功,500 表示Server内部错误等。

主要信息就这么点。最后是要解放思想,Web端不再用之前典型的PHP或JSP架构,而是改为前段渲染和附带处理简单的商务逻辑(比如AngularJS或者BackBone的一些样例)。Web端和Server只使用上述定义的API来传递数据和改变数据状态。格式一般是JSON。iOS和Android同理可得。由此可见,Web,iOS,Android和第三方开发者变为平等的角色通过一套API来共同消费Server提供的服务。

粒度!

———————————转简书内容———————————————

restful接口设计规范总结

重要概念:

REST,即Representational State Transfer的缩写。我对这个词组的翻译是"表现层状态转化"。

Resource(资源) :对象的单个实例。 例如,一只动物。它可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的实在。你可以用一个URI(统一资源定位符)指向它,每种资源对应一个特定的URI。要获取这个资源,访问它的URI就可以,因此URI就成了每一个资源的地址或独一无二的识别符。

集合:对象的集合。 例如,动物。

第三方:使用我们接口的开发者

表现层(Representation)

"资源"是一种信息实体,它可以有多种外在表现形式。我们把"资源"具体呈现出来的形式,叫做它的"表现层"(Representation)。

状态转化(State Transfer)

访问一个网站,就代表了客户端和服务器的一个互动过程。在这个过程中,势必涉及到数据和状态的变化。互联网通信协议HTTP协议,是一个无状态协议。这意味着,所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生"状态转化"(State Transfer)。而这种转化是建立在表现层之上的,所以就是"表现层状态转化"。

客户端用到的手段,只能是HTTP协议。具体来说,就是HTTP协议里面,四个表示操作方式的动词:GET、POST、PUT、DELETE。它们分别对应四种基本操作:GET用来获取资源,POST用来新建资源(也可以用于更新资源),PUT用来更新资源,DELETE用来删除资源。

比如,文本可以用txt格式表现,也可以用HTML格式、XML格式、JSON格式表现,甚至可以采用二进制格式;图片可以用JPG格式表现,也可以用PNG格式表现。

URI只代表资源的实体,不代表它的形式。严格地说,有些网址最后的".html"后缀名是不必要的,因为这个后缀名表示格式,属于"表现层"范畴,而URI应该只代表"资源"的位置。它的具体表现形式,应该在HTTP请求的头信息中用Accept和Content-Type字段指定,这两个字段才是对"表现层"的描述。

综合上面的解释,我们总结一下什么是RESTful架构:

(1)每一个URI代表一种资源;

(2)客户端和服务器之间,传递这种资源的某种表现层;

(3)客户端通过四个HTTP动词,对服务器端资源进行操作,实现"表现层状态转化"。

REST接口规范

动作

GET (SELECT):从服务器检索特定资源,或资源列表。
POST (CREATE):在服务器上创建一个新的资源。
PUT (UPDATE):更新服务器上的资源,提供整个资源。
PATCH (UPDATE):更新服务器上的资源,仅提供更改的属性。
DELETE (DELETE):从服务器删除资源。

首先是四个半种动作:
post、delete、put/patch、get
因为put/patch只能算作一类,所以将patch归为半个。

另外还有有两个较少知名的HTTP动词:
HEAD - 检索有关资源的元数据,例如数据的哈希或上次更新时间。
OPTIONS - 检索关于客户端被允许对资源做什么的信息。

路径(接口命名)

路径又称"终点"(endpoint),表示API的具体网址。

在RESTful架构中,每个网址代表一种资源(resource),所以网址中不能有动词,只能有名词,而且所用的名词往往与数据库的表格名对应。一般来说,数据库中的表都是同种记录的"集合"(collection),所以API中的名词也应该使用复数。

举例来说,有一个API提供动物园(zoo)的信息,还包括各种动物和雇员的信息,则它的路径应该设计成下面这样。

接口尽量使用名词,禁止使用动词,下面是一些例子。

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:删除某个指定动物园的指定动物

反例:

/getAllCars

/createNewCar

/deleteAllRedCars

再比如,某个URI是/posts/show/1,其中show是动词,这个URI就设计错了,正确的写法应该是/posts/1,然后用GET方法表示show。

如果某些动作是HTTP动词表示不了的,你就应该把动作做成一种资源。比如网上汇款,从账户1向账户2汇款500元,错误的URI是:

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

正确的写法是把动词transfer改成名词transaction,资源不能是动词,但是可以是一种服务:

POST /transaction HTTP/1.1
  Host: 127.0.0.1
  from=1&to=2&amount=500.00

理清资源的层次结构,比如业务针对的范围是学校,那么学校会是一级资源(/school),老师(/school/teachers),学生(/school/students)就是二级资源。

版本(Versioning)

应该将API的版本号放入URL。如:

https://api.example.com/v1/

另一种做法是,将版本号放在HTTP头信息中,但不如放入URL方便和直观。Github采用这种做法。

过滤信息(Filtering)

如果记录数量很多,服务器不可能都将它们返回给用户。API应该提供参数,过滤返回结果。
下面是一些常见的参数。

?limit=10:指定返回记录的数量

?offset=10:指定返回记录的开始位置。

?page_number=2&page_size=100:指定第几页,以及每页的记录数。

?sortby=name&order=asc:指定返回结果按照哪个属性排序,以及排序顺序。

?animal_type_id=1:指定筛选条件

参数的设计允许存在冗余,即允许API路径和URL参数偶尔有重复。比如,

GET /zoo/ID/animals 与 GET /animals?zoo_id=ID 的含义是相同的。

状态码(Status Codes)

状态码范围

1xx 信息,请求收到,继续处理。范围保留用于底层HTTP的东西,你很可能永远也用不到。

2xx 成功,行为被成功地接受、理解和采纳

3xx 重定向,为了完成请求,必须进一步执行的动作

4xx 客户端错误,请求包含语法错误或者请求无法实现。范围保留用于响应客户端做出的错误,例如。他们提供不良数据或要求不存在的东西。这些请求应该是幂等的,而不是更改服务器的状态。

5xx 范围的状态码是保留给服务器端错误用的。这些错误常常是从底层的函数抛出来的,甚至

开发人员也通常没法处理,发送这类状态码的目的以确保客户端获得某种响应。

当收到5xx响应时,客户端不可能知道服务器的状态,所以这类状态码是要尽可能的避免。

服务器向用户返回的状态码和提示信息,常见的有以下一些(方括号中是该状态码对应的HTTP动词)。

200 OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。

201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。

202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务)

204 NO CONTENT - [DELETE]:用户删除数据成功。

400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。

401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。

403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。

404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。

406 Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。

410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。

422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。

500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。

502 网关错误

503 Service Unavailable

504 网关超时

参考资料:

RESTful API 设计指南--阮一峰:http://www.ruanyifeng.com/blog/2014/05/restful_api.html

文章来源:刘俊涛的博客

欢迎关注,有问题一起学习欢迎留言、评论

RESTful到底是什么玩意??相关推荐

  1. 架构师到底是啥玩意?

    前天晚上下班回家,和同事一起在地铁上聊起了架构师的问题.有一点自己的愚见,可以分享一下. 架构师到底是啥玩意?不管是在校科班学生,还是刚入行的菜鸟,或者已经有相对工作经验的朋友,只要一听到架构师这个称 ...

  2. matlab中prbs怎么用,答题 | PRBS码到底是啥玩意?

    原标题:答题 | PRBS码到底是啥玩意? [文:黄刚] 问 答 如果是prbs7.prbs15呢?它们循环一次需要多少个bit呢?那--拓展到prbsN呢? 咳咳,这个问题从我发出去开始就知道难不倒 ...

  3. 时钟系统:CPU为啥需要时钟;此时钟非彼时钟,时钟到底是啥玩意

    CPU为啥需要时钟:此时钟非彼时钟,时钟到底是啥玩意 讨论问题: 2.2 时钟的本质 讨论问题: 1.时钟是什么 2. 为什么需要时钟 2.2 时钟的本质 不知道你有没有过类似的疑惑:CPU不是供电就 ...

  4. JavaScript_proto_和prototype到底是什么玩意

    JavaScript_proto_和prototype到底是什么玩意 今天去逛了贴吧,发现有人在问instanceof 的类型比较,所以比较贴心的去解释了一下,instanceof是比较左侧的_pro ...

  5. 快应用、快服务、服务直达…这些到底是啥玩意

      4月8日华为终于在国内线上发布会发布了P40及P40pro,但是与此同时也发布了华为智慧屏X65, 华为音响Sound X,支持双扬声器.无线充电.通话降噪的 HUAWEI Eyewear 眼镜, ...

  6. 拯救跟我一样的初学者:XML到底是什么玩意,用能让初学者听得懂的话

    我也是个初学者,看视频在XML里添加来添加去都不知道干嘛用就来百度结果TM的一堆各种名词,根本不是给我这个初学者科普的,但是一堆沙子里也有黄金,我就把我觉得好的解释放在下面. **解释1:** 来源: ...

  7. 「长文预警」云计算、人工智能、大数据到底是啥玩意?

    作者:刘超的通俗云计算 我今天要讲这三个话题,一个是云计算,一个大数据,一个人工智能,我为什么要讲这三个东西呢?因为这三个东西现在非常非常的火,它们之间好像互相有关系,一般谈云计算的时候也会提到大数据 ...

  8. 运筹学到底是啥玩意?

    哈喽,各位大佬好,我是小明哥,初次实际遇到这个概念是在某次面试中,面试官说他们需要运筹学的相关人员来解决家居布置的问题(到达最优,但我不知道怎么才算最优,不知道label,所以有点懵逼),当时我对陌生 ...

  9. i386 与amd64到底谁个什么玩意?

    简单的来讲,这两个表示安装包是几位的.i386就是32位的,amd64就是64位的.他们既可以安装在intel的cpu上,也可以安装在AMD的CPU上.我就是因为没注意这个,就又重新安装了一遍Ubun ...

最新文章

  1. 孩子,别熬夜了,伤DNA
  2. 【云计算】4_CDN加速产品介绍
  3. HDU 2149-Public Sale(巴什博奕)
  4. 萨默尔机器人_第四届丝博会人工智能受热捧 机器人会送餐会协助办案
  5. python个人收支管理系统相关题目_练手题:计算人均付费(SQLPython)
  6. 移动端相关 em rem px 区别和关联
  7. LeetCode : Number of Segments in a String
  8. jitter单位_产生jitter的原因
  9. 1、深入理解 Laravel Eloquent(一)——基本概念及用法
  10. 如何将符号保存到php数据库当中并且打印出来!
  11. 树莓派人脸识别源代码
  12. java-net-php-python-java《Linux基础及技术》课程网站演示录像修改计算机毕业设计程序
  13. STM32 PWM输出
  14. Android开发局域网通信软件笔记
  15. 03、【电脑维修】防火墙丢失,找不到 windows firewall服务, windows defender firewall服务被禁用或防火墙无法打开
  16. NGINX根据客户端真实ip限制/referer限制
  17. 机器学习实战笔记(一)机器学习基础
  18. 燎原老师python_Python之火,可以燎原
  19. Python控制键盘鼠标pynput的详细用法 (转载)
  20. 汽车市场勇进派 乐车邦林金文的逆周期生意

热门文章

  1. grpc通信原理_容器原理架构详解(全)
  2. msbuild 语法_用于删除文件的MSBuild Task语法
  3. C读取配置文件,然后写入结构体的方法
  4. Java正则表达式校验工具类_【Java工具类】----正则表达式校验工具类
  5. 计算机课做ppt的软件有哪些内容,课程内容计算机软件的基础知识.ppt
  6. python求交点坐标_Python求两个圆的交点坐标或三个圆的交点坐标方法
  7. python配置opencv最简单_(Python)从零开始,简单快速学机器仿人视觉Opencv—第二节:OpenCV的视频操作...
  8. 离散数学专业术语(continuous updating)
  9. FPGA的设计艺术(16)逻辑设计中无刻不在的判断之if/case语句
  10. HDLBits 系列(23)3 输入的 LUT