restful的幂等性解释

Posted 程序员的江湖

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了restful的幂等性解释相关的知识,希望对你有一定的参考价值。

1.概念解释

   幂等性

      http幂等方法,是指无论调用多少次都不会产生不同副作用(数据变更)的http方法

   简单解释:

         重复发送同一个请求多次,结果同发送一次

   操作示例:

         GET /tickets # 获取ticket列表

         GET /tickets/12 # 查看某个具体的ticket

         POST /tickets # 新建一个ticket

         PUT /tickets/12 # 更新ticket 12

         PATCH /tickets/12 # 更新ticket 12

         DELETE /tickets/12 # 删除ticekt 12

2.HTTP GET(幂等)

   get用于获取资源,不管调用多少次接口,返回结果保持不变,不会改变资源。如:

   第一次调用 GET /tickets , 后台返回tickets列表(我想看下还有多少张票)

   第二次调用 GET /tickets , 返回同样的数据(我想再看一遍tickets信息)

   ps: 我多看一眼,总不会把你的票看没了吧,我看或者不看你就在那里

3.HTTP POST(非幂等)

    post用于创建资源,每次调用都会创建一个新的资源,如

    第一次调用 POST /tickets ,后台产生 /tickets/1 这么一个资源(我要新增一张票)

    第二次调用 POST /tickets , 后台产生 /tickets/2 这么一个资源(我要再新增一张票)

    ps:我是生产车票的,所以我不会产生重复的车票(id至少不一样)

4.HTTP PUT(幂等)

    put用于更新资源,没有的话则执行创建操作。如:

    第一次调用 PUT /tickets/11 , 后台创建 /tickets/11 (帮我看下11号票在不在,在的话更新下状态,不在的话创建下)

   第二次调用 PUT /tickets/11 , 后台更新 /tickets/11 (帮我看下11号票在不在,在的话更新下状态,不在的话创建下)

   由于两次请求携带的数据是一样的,所以不论请求多少次,最终的结果都是后台存在这么一个资源(创建或更新)

   ps:我有强迫症加健忘症,同样的事我可能会让你干很多遍,你给我小心处理哈,我可不想看到不同的结果

5.HTTP DELETE(幂等)

   delete用于删除资源,会将资源从后台删除。如:

   第一次调用 DELETE /tickets/11 , 后台删除 /tickets/11对应的数据信息 (11号票我不要了,帮我删除下吧)

   第二次调用 DELETE /tickets/11 , 后台判断 /tickets/11不存在,无操作(11号票我不记得有没有删除,帮我删除下吧)

   ps:我也有健忘症啊,同样的事我也可能会干很多遍,你忽略就好了,给我个眼神(返回码),我就知道了

6.备注

   /tickets/12 这种叫做uri,一个uri代表一个资源,本例中代表一张票(实际可能对应数据库中的一行信息),

    所以上述描述的创建,删除,更新资源,都是指根据uri及其所附带信息实际操作uri对应的后台资源。


以上是关于restful的幂等性解释的主要内容,如果未能解决你的问题,请参考以下文章

细说Restful API之幂等性

iOS 学习 RESTful 中 Http 的幂等性

HTTP中的幂等性

幂等性学习及接口的幂等性

接口的幂等性

TODO什么是幂等性?如何保证接口的幂等性?