网站提供的每一个web服务都须要先后端交互,先后端交互的实现方案,一般叫做:web服务交互方案。css
1)REST(Representational State Transgfer)表述性状态转移html
REST是Roy Thomas Fielding博士于2000年在他的博士论文里提出来的。python
REST相比SOAP更加简洁,性能和开发效率也有突出的优点。git
2)SOAP(Simple Object Access Protoco)简单的对象访问协议github
SOAP服务则是以自己所定义的操做集,来访问网络上的资源。web
SOAP也是基于XML的,可是它不仅限于HTTP协议的传输,包括TCP协议,UDP协议均可以传输。数据库
3)XML-RPC(XML Remote Procedure Call)基于XML的远程过程调用django
XML-RPC是经过XML将调用函数封装,并使用HTTP协议做为传送机制。后来在新的功能不断被引入下,这个标准慢慢演变成为今日的SOAP协定。编程
REST与技术无关,表明的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为“表征状态转移”。json
这里说的表征性,其实就是资源。一般称为资源状态转移。
什么事物,只要有被引用的必要,它就是一个资源。资源能够是一个实体,也能够是抽象概念。
实体资源很好理解,我的信息、手机号、视频、图片等等都是实实在在存在的实体。而两我的的关系则是抽象的概念。
在网络中要引用资源,资源必定要有一个标识,在web中惟一标识就是URI。
URI:统一资源标志符(相似身份证号)。URL:统一资源定位符(相似家庭住址)。
URI是给资源进行标识的,URL是描述资源地址的。
经过这两种方式均可以找到咱们的资源,其实URL能够说是URI的子集,经过定位的方式实现的URI。
得到URL后,能够经过URL去访问到资源,但对资源会有不少不一样的操做(增删改查)。以前的方式是分别设计一个新的URL来对数据进行操做。
如今只须要一个URL,根据HTTP请求方式不一样,对资源进行不一样的操做,这就是统一资源接口。
资源的表述其实就是资源的展示形式,客户端和服务端传输的都是资源的表述,而不是资源自己。
例如文本资源能够采用html、xml、json等格式,图片可使用PNG或JPG展示出来。
那么客户端如何知道服务端提供哪一种表述形式呢?
能够经过HTTP内容协商,客户端能够经过Accept头请求一种特定格式的表述,服务端则经过Content-Type告诉客户端资源的表述形式。
这些资源的表述呈如今页面上,就是咱们说的资源状态。
看页面的时候,从当前资源的表述(也能够说状态或者表现层)会跳转到其余的资源状态。
服务端经过超媒体告诉客户端当前状态有哪些后续状态能够进入。
这些相似"下一页"之类的连接起的就是这种推动状态的做用——指引你如何从当前状态进入下一个可能的状态。
REST与技术无关,表明的是一种软件架构风格,REST是Representational State Transfer的简称,中文翻译为“表征状态转移”
REST从资源的角度类审视整个网络,它将分布在网络中某个节点的资源经过URL进行标识,客户端应用经过URL来获取资源的表征,得到这些表征导致这些应用转变状态
全部的数据,无论是经过网络获取的仍是操做(增删改查)的数据,都是资源,将一切数据视为资源是REST区别与其余架构风格的最本质属性
对于REST这种面向资源的架构风格,有人提出一种全新的结构理念,即:面向资源架构(ROA:Resource Oriented Architecture)。
若是一个架构符合REST的约束条件和原则,咱们就称它为RESTful架构。一种软件的架构风格,设计风格, 为客户端和服务端的交互提供一组设计原则和约束条件。
理解RESTful架构:http://www.ruanyifeng.com/blog/2011/09/restful.html
API与用户的通讯协议,老是使用HTTPs协议。
应该将API的版本号放入URL。另外一种作法是,将版本号放在HTTP头信息中,但不如放入URL方便和直观。Github采用这种作法。
路径又称"终点"(endpoint),表示API的具体网址。
在RESTful架构中,每一个网址表明一种资源(resource),因此网址中不能有动词,只能有名词,并且所用的名词每每与数据库的表格名对应。通常来讲,数据库中的表都是同种记录的"集合"(collection),因此API中的名词也应该使用复数。
视网络上任何东西都是资源,均使用名词表示(可复数)
对于资源的具体操做类型,由HTTP动词表示。
经常使用的HTTP动词有下面五个,后面是对应的SQL命令。
还有两个不经常使用的HTTP动词:
示例:
- 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:删除某个指定动物园的指定动物
若是记录数量不少,服务器不可能都将它们返回给用户。API应该提供参数,过滤返回结果。
经过在url上传参的形式传递搜索条件
参数的设计容许存在冗余,即容许API路径和URL参数偶尔有重复。好比,GET /zoo/ID/animals 与 GET /animals?zoo_id=ID 的含义是相同的。
服务器向用户返回的状态码和提示信息,常见的有如下一些(方括号中是该状态码对应的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 - [*]:服务器发生错误,用户将没法判断发出的请求是否成功。 更多看这里:http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html
状态码是4xx时,应向用户返回错误信息,通常来讲,返回的信息中将error做为键名,出错信息做为键值便可。
{ error: "Invalid API key" }
针对不一样操做,服务器向用户返回的结果应该符合如下规范。
GET /collection:返回资源对象的列表(数组) GET /collection/resource:返回单个资源对象 POST /collection:返回新生成的资源对象 PUT /collection/resource:返回完整的资源对象 PATCH /collection/resource:返回完整的资源对象 DELETE /collection/resource:返回一个空文档
RESTful API最好作到Hypermedia,即返回结果中提供连接,连向其余API方法,使得用户不查文档,也知道下一步应该作什么。
好比,当用户向api.example.com的根目录发出请求,会获得这样一个文档。
{"link": { "rel": "collection https://www.example.com/zoos", "href": "https://api.example.com/zoos", "title": "List of zoos", "type": "application/vnd.yourformat+json" }}
上面代码表示,文档中有一个link属性,用户读取这个属性就知道下一步该调用什么API了。rel表示这个API与当前网址的关系(collection关系,并给出该collection的网址),href表示API的路径,title表示API的标题,type表示返回类型。
Hypermedia API的设计被称为HATEOAS。Github的API就是这种设计,访问api.github.com会获得一个全部可用API的网址列表。
在url接口中推荐使用Https协议,让网络接口更加安全(Https是Http的安全版,即HTTP下加入 SSL层,HTTPS的安全基础是SSL,所以加密的详细内容就须要SSL(安全套接层协议));
https://www.bootcss.com/v1/mycss
https://v1.bootcss.com/mycss
https://www.bootcss.com/v1/mycss
https://v1.bootcss.com/mycss
不一样的版本能够有不一样的接口,使其更加简洁,清晰。
restful 提倡面向资源编程,因此在url接口中尽可能要使用名词,不要使用动词。
添加条件去筛选匹配:
https://www.bootcss.com/v1/mycss?page=3
能够根据Http不一样的method,进行不一样的资源操做(5种方法:GET / POST / PUT / DELETE/ PATCH)
能够经过状态码直接判断服务器的响应信息。
1** 信息,服务器收到请求,须要请求者继续执行操做
2** 成功,操做被成功接收并处理
3** 重定向,须要进一步的操做以完成请求
4** 客户端错误,请求包含语法错误或没法完成请求
5** 服务器错误,服务器在处理请求的过程当中发生了错误
应该有返回值,并且格式为统一的json格式。
GET请求 返回查到全部或单条数据
POST请求 返回新增的数据
PUT请求 返回更新数据
PATCH请求 局部更新 返回更新整条数据
返回值携带错误信息。
若是遇到须要跳转的状况,携带跳转接口的URL。
返回结果中要提供帮助连接,即API最好作到Hypermedia。
ret = { code: 1000, data:{ id:1, name:'小强', depart_id:http://www.luffycity.com/api/v1/depart/8/ } }