1. 8种常见的http请求类型
HTTP协议中请求的8中方法:
-
OPTIONS
获取服务器支持的HTTP请求方法; -
HEAD
跟get很像,但是不返回响应体信息,用于检查对象是否存在,并获取包含在响应消息头中的信息。 -
GET
向特定的资源发出请求,得到资源。 -
POST
向指定资源提交数据进行处理的请求,用于添加新的内容。 -
PUT
向指定资源位置上传其最新的内容,用于修改某个内容。 -
DELETE
请求服务器删除请求的URI所标识的资源,用于删除。 -
TRACE
回馈服务器收到的请求,用于远程诊断服务器。 -
CONNECT
用于代理进行传输,如使用ssl
幂等idempotent:如果一个方法重复执行多次,产生的副作用(效果)是一样的,那就是幂等的。幂等的意思是如果相同的操作执行一次和N次,其对资源本身产生的副作用相同。如GET不会改变资源本身的状态,即使执行N次,虽然得到的结果可能不同,但对于资源本身不会产生副作用,所以属于幂等操作。而对于DELETE操作,对资源会产生副作用,但是调用一次和N次对资源产生的副作用是一致的(如删除id=123的item调用N次对数据库的影响一样),属于幂等操作。
比较:
1. POST /api/articles
2. PUT /gists/:id/stars
- 如果最终产生两个资源,即多次调用产生了不同副作用,则该服务不是idempotent(幂等的)=> POST
- 如果下一个请求把上一求的结果所覆盖,那该服务就是idempotent的 => PUT/PATCH
2. 关于POST/PUT/PATCH/的区别
2.1 POST:用来创建一个子资源
如 /api/users,会在users下面创建一个user,如users/1;POST方法不是幂等的,多次执行,将导致多条相同的条目被创建。(比如在提交表单时刷新,会POST多个相同的表单给服务器)。
重点:POST不是幂等的
2.2 PUT:Create or Update
例如 PUT /items/1 的意思是替换 /items/1 ,存在则替换,不存在则创建。
重点: PUT方法一般用于更新一个已知资源。
2.3 PATCH:Update partly
PATCH是对PUT方法的补充,用来对已知资源进行局部更新。假设我们有一个UserInfo,里面有userId, userName, userGender等10个字段。对于该数据类型的更新:
PUT:把一个包含了修改后userName的完整userInfo对象传给后端,做完整更新。
PATCH:只传一个userName到指定资源去,表示该请求是一个局部更新,后端仅更新接收到的字段。
注意:PUT虽然也是更新资源,但要求前端提供的一定是一个完整的资源对象,理论上说,如果你用了PUT,但却没有提供完整的UserInfo,那么缺了的那些字段应该被清空。另外PUT会有一个create操作,加入更新的id不存在,会进行创建,而PATCH则没有这个。
重点:PATCH是幂等的
3. Batch Request
总的来说,请求分为两类:
- 请求静态资源
- 请求数据渲染
To be continued.