HTTP 学习之请求方法

请求方法

1、OPTIONS:这个方法可使服务器传回该资源所支持的所有HTTP请求方法。用'*'来代替资源名称,向Web服务器发送OPTIONS请求,可以测试服务器功能是否正常运作。

2、HEAD:与GET方法一样,都是向服务器发出指定资源的请求。只不过服务器将不传回资源的本文部份。它的好处在于,使用这个方法可以在不必传输全部内容的情况下,就可以获取其中“关于该资源的信息”(元信息或称元数据)

3、GET:向指定的资源发出“显示”请求。使用GET方法应该只用在读取数据,而不应当被用于产生“副作用”的操作中,例如在Web Application中。其中一个原因是GET可能会被网络蜘蛛等随意访问。参见安全方法

4、POST:向指定资源提交数据,请求服务器进行处理(例如提交表单或者上传文件)。数据被包含在请求本文中。这个请求可能会创建新的资源或修改现有资源,或二者皆有。

5、PUT:向指定资源位置上传其最新内容。

6、DELETE:请求服务器删除Request-URI所标识的资源。

7、TRACE:回显服务器收到的请求,主要用于测试或诊断。

8、CONNECT: HTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。通常用于SSL加密服务器的链接(经由非加密的HTTP代理服务器)

方法的安全性和幂等性

方法名    安全性      幂等性

GET  是 是

HEAD  是 是

OPTIONS  是 是

DELETE  否 是

PUT  否 是

POST  否 否

1、HTTP请求方法的安全性指的是:Server处理这些方法时,资源的一致性,稳定性等问题(资源状态)。

2、HTTP的幂等性指的是:不会改变资源的状态,不论调用一次还是N次都有相同的副作用。请注意,这里强调的是一次和N次具有相同的副作用,而不是每次请求的结果。本质上,幂等性的设计就是替代分布式事务的设计,通过增加一个id来解决事务过程的“冲突”。

3、可以认为安全的方法都是只读的方法(GET, HEAD, OPTIONS),不会改变资源状态,显然,这三个方法也是幂等的。

4、DElETE方法是不安全的,但是是幂等的。

5、PUTPOST方法语义中都有修改资源状态的意思,因此都不是安全的。但是PUT方法是幂等的,POST方法不是幂等的,这么设计的理由是:HTTP协议规定,POST方法修改资源状态时,URL指示的是该资源的父级资源,待修改资源的ID信息在请求体中携带。而PUT方法修改资源状态时,URL直接指示待修改资源。因此,同样是创建资源,重复提交POST请求可能产生两个不同的资源,而重复提交PUT请求只会对其URL中指定的资源起作用,也就是只会创建一个资源。

请求方法比较

1、GETEAD是获取某资源,是安全的,等幂的,所有UAServer能够缓存相关信息。

2、GETHEAD提交信息时,将数据放入到URL中,协议虽为限制其长度,不过一般不超过2K

3、POST 是对相关资源进行添加操作,是不安全,不等幂的,Server不能缓存相关信息。

4、POST 提交信息是数据放在HTTP实体中,长度受Server配置的限制。

5、在通信中GET的安全性较低,POST的安全性较高。

http://zh.wikipedia.org/wiki/%E8%B6%85%E6%96%87%E6%9C%AC%E4%BC%A0%E8%BE%93%E5%8D%8F%E8%AE%AE

http://baike.baidu.com/view/9472.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值