Restful web 服务四种操作post/delete/put/get 区别

Http请求主要由以下几种请求方式
post,get,put,delete
这里写图片描述

post:请求体在body里面
get:请求在链接后面
put:请求方式和post一样
delete:请求方式和post一样

但是,既然请求方式一样,为什么还要区分post和put呢?
原因:
后端接收到post请求还可以转发请求到其他地址,而put请求不允许转发!

学术上讲就是:
post是作用于一个集合资源之上的(/uri),而put操作是作用在一个具体的资源上的。如果我们能确定url不会再被转发,那么就是用put,如果服务器需要对url进行转发,那么就是用post。如果在put请求中,服务器希望该请求应用到另一个url,就必须发送一个301响应,让用户自己去判断决定是否转发该请求。
这里写图片描述

学术上讲解其他几种请求类型。
GET操作是安全的。所谓安全是指不管进行多少次操作,资源的状态都不会改变。比如我用GET浏览文章,不管浏览多少次,那篇文章还在那,没有变化。当然,你可能说每浏览一次文章,文章的浏览数就加一,这不也改变了资源的状态么?这并不矛盾,因为这个改变不是GET操作引起的,而是用户自己设定的服务端逻辑造成的。

PUT,DELETE操作是幂等的。所谓幂等是指不管进行多少次操作,结果都一样。比如我用PUT修改一篇文章,然后在做同样的操作,每次操作后的结果并没有不同,DELETE也是一样。顺便说一句,因为GET操作是安全的,所以它自然也是幂等的。

POST操作既不是安全的,也不是幂等的,比如常见的POST重复加载问题:当我们多次发出同样的POST请求后,其结果是创建出了若干的资源。

安全和幂等的意义在于:当操作没有达到预期的目标时,我们可以不停的重试,而不会对资源产生副作用。从这个意义上说,POST操作往往是有害的,但很多时候我们还是不得不使用它。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值