最近写了几个有关RESTful的API相关内容,也谈谈对常见问题的本身的理解。html
详情能够看http://www.ruanyifeng.com/blog/2011/09/restful.html。前端
简单能够这么理解,使用URI
去表明资源,使用HTTP VERB(GET PUT等)对资源的操做。git
使用RESTful,优势有不少,也方便不一样的请求方去请求数据。列举两个:github
那是否是每个API都须要使用REST风格呢?我以为不是,这要看团队、项目而定,没必要一味强求。json
这个涉及到RESTful的版本管理,常见的方法有这么几种。api
/api/v1/helloworld
不少公开的API地址里面,都带有version信息,若是非要去扣符不符合RESTful,估计要吵起来。可是这个方式很便捷、明确,调用方一看就明白,也没有额外的工做量去作。不过缺点也很明显,因为已经限定死了版本号在URI中,没法实现同一个URI地址版本的灵活切换,也不能指定默认版本。安全
/api/helloworld?api-version=1.0
这个方式没有改变URI自己,可是须要调用方去额外处理Query string,不过好在这个能够指定默认的。服务器
POST api/helloworld HTTP/1.1 host: localhost content-type: text/plain;v=2.0 content-length: 12 Hello there!
在Content-Type里面添加v=x.x的版本号也是一个不错的选择,能够实现QueryString相似的功能。restful
有一些现成的库能够帮助咱们实现上面的Versioning方法,常见的是aspnet-api-versioningpost
不管请求多少次,服务器的状态(资源)都不会改变,那么这个方法就是安全的。
GET HEAD都应该设计成安全的。
不管对资源操做多少次,服务器资源结果老是同样的,那么这个方法就是幂等的。注意这里的说法,是服务器的资源结果是同样的,不表明请求的返回结果是同样的。好比DELETE请求,它是幂等的,可是删除一个资源不少次的状况(屡次执行DELETE api/student/1
,第一次返回成功,第二次返回失败,可是不影响服务器上对应的记录已经删除的状态。
GET、HEAD、PUT和DELETE请求都应该设计成是幂等的。
资源新增能够用POST也能够用PUT,可是设计上有几个区别。
PUT是幂等的,POST不是,若是设计上须要不该用幂等性,那么使用POST。好比POST计数器的应用,每次POST,计数器都增加1。
POST通常请求的是资源集合,而PUT通常请求是一个具体的资源。
PUT /students/{id} POST /students
这也意味着,语义上,POST是请求在集合中新增资源。
PUT语义是要求覆盖的,若是数据已经存在,就必须覆盖。POST的没有这个要求,能够有别的行为。
不必定,要看状况。PUT是覆盖性的修改,而PATCH是追加性的修改。
{ "value": { "id": "235314", "deviceId": "123", "type": "低温" } }
若是发送的数据只含有deviceId,执行PUT以后,资源变成:
{ "value": { "id": "235314", "deviceId": "111" } }
执行PATCH,资源变成:
{ "value": { "id": "235314", "deviceId": "111", "type": "低温" } }
问题:
若是请求一个这样的资源
GET api/sutudents/homework
在没有homework的状况下应该返回HTTP 204 NoContent仍是返回HTTP 404 NotFound?
乍看一眼,以为好像都差很少,没内容和没找到反正都是没有。但深刻想一想,仍是有很大的区别的。
因此,对于上面的问题,这么理解,若是homework是已经建立的资源,可是内容为空,那么返回204是能够的,可是若是homework这个东西就不存在,那么应该返回404。
我的认为直接返回200,携带对应的空内容会比204要对调用方更加友好,至少和有数据的状况是同样处理。
有不少前端同窗须要服务器返回固定的成功信息(好比200)或者错误信息(好比400)。但HTTP CODE不少,一个一个判断效率很低,好在HTTP CODE是分类的,好比2xx大致是OK的,4xx都是有问题的。能够经过CODE / 100 == 2
之类的方法去大致肯定返回的状态 。