因此,假设Http中的DELETE谓词是幂等的,当我发出以下请求时,第二个(或第三个,或第四个,等等)会发生什么?
DELETE /person/123
Run Code Online (Sandbox Code Playgroud)
第一次,资源被删除,我返回204(成功,没有内容).我应该在后续电话或404(未找到)上返回204吗?
我正在学习REST和PUT/DELETE,我已经读过这两个(以及GET)是幂等的意思是多个请求使服务器进入相同的状态.
重复的PUT/DELETE请求是否会离开Web浏览器(使用时XMLHttpRequest)?换句话说,服务器是否会为每个PUT请求更新相同的数据库记录,还是会自动忽略重复的请求?
如果是,那么使用PUT或DELETE与使用POST有何不同?
我读了一篇文章,建议RESTful Web服务是前进的方向.HTML5表单不支持PUT/DELETE方法有什么特别的原因吗?
所以HTTP规范说HTTP PUT和DELETE应该是幂等的.这意味着,对具有相同正文的同一URL的多个PUT请求不应导致服务器上的其他副作用.多个HTTP DELETE也是如此,如果将2个或更多DELETE请求发送到同一个URL,则第二个(或第三个等)请求不应返回指示资源已被删除的错误.
但是,在处理完DELETE之后,PUT对URI的请求呢?它应该返回404吗?
例如,请考虑以下顺序执行以下请求:
item资源,返回HTTP 201和URI/api/items/6item#6 相关的数据item#6并返回HTTP 202那么,如果PUT与获取和返回404一致,或者像@CodeCaster建议的那样,409会更合适吗?
我有一个REST API,其中多个客户端(应用程序)可以使用PUT更新资源的状态.例如,此资源是您可以转动的灯ON或OFF.
当系统检测到发生电力故障时,该资源也会自动更新,导致灯处于BROKEN state. I want to made the distinction between BROKEN状态.我想区分OFF和BROKEN,一盏灯ON不能转PUT!
我用PUT http://address:port/my_lamp { "state": "ON"} 方法来做这件事,比如说PUT
但我不确定我是否尊重ON方法的幂等属性.事实上,我有3个案例:
ON.上面的代码导致了ON状态.ON.上面的代码导致了BROKEN状态....很酷!此时,幂等性仍然有保证:-)!503 Service Unavailable.上面的代码会导致错误,例如PUT我不确定正确理解幂等性的概念.相信我,我读了很多关于它的事情,但仍然有点困惑.
在我的理解中,多个BROKEN总是导致资源的相同状态:在我的情况下不能保证由于PUT
但我也可以用另一种方式来理解它:多重ON总是导致相同的副作用:保证,我的请求要么产生转动BROKEN,要么没有(对于这种ON情况,它已经存在).
ON灯泡,这是保证的(它要么开启,要么在这里什么都不做)
请参阅此处:REST DELETE真的是幂等的吗?
哪一个是正确的?根据理解,我的REST API确保了幂等性能......
只是一个关于 REST Web 服务HTTP DELETE方法的基本问题。根据 HTTP 协议文档,DELETE是幂等的。但是我们第一次发送时,您会收到 200 响应代码,随后的请求会收到 404 错误,因为该资源不存在。那么,如果响应不同,为什么它会被称为幂等呢?