这是百度搜索答案TOP1,通过查阅官方资料。发现答案基本是错的,下面根据答案逐一分析:
(1) Get是从服务器上获取数据,Post是向服务器传送数据。
反驳:先看HTTPPFC文档对这两个请求的定义。根据HTTP规范,Get用来信息获取,应该是安全的和幕等的。Post表示可能会修改服务器资源的请求
简单的来说,发送请求的角度。Get请求相当于在数据库做了查询,这样不会影响数据库本身的数据,从接受返回数据的角度,幕等的含义简单就是说发送Get请求不改变返回数据的内容。
(2)Get是把参数数据队列加到提交表单的ACTION属性所指的URL中,值和表单内各个字段一一对应,在URL中可以看到。Post是通过HTTP Post机制,将表单内各个字段与其内容放置在HTML HEADER内一起传送到ACTION属性所指的URL地址。用户看不到这个过程。
反驳:这个答案是在叙述Get和Post表现形式不同。Get请求数据回复在URL之后,也就是把数据放置在HTTP协议头里面,以?分割URL和传输数据,多个参数用&链接。Post请求就是吧提交的数据放置在HTTP包的body中。
这种形式是HTML标准对HTTP协议用法的约定,不能作为Post和Get请求的区别,因为现在有很多WebServer支持Get包含body的表现。所以答案是错误的。
(3)对于Get方式,服务器端用Request.QueryString获取变量的值,对于Post方式,服务器端用Request.Form获取提交的数据。 反驳:这个答案完全是误导,获取请求变量的值是服务端配置决定的,与Post和Get毫无关系
(4)Get传送的数据量较小,不能大于2KB。Post传送的数据量较大,一般被默认为不受限制。但理论上,IIS4中最大量为80KB,IIS5中为100KB。
反驳:查看过HTTP协议规范就能知道,没有对传输的数据大小有限制,也没有对URL长度进行限制。如果非要说Get请求URL有闲置的话,那么只有2种原因
1.HTTP客户端浏览器自己的限制。例如IE限制URL长度为2083字节,opera是4050字节,Netscape是8192等
2.Web服务器为了效率和安全考虑,所以修改Apache,IIS的配置对Post提交数据大小进行限制,限制不能作为Post和Get请求的区别。所以答案还是错的
(5) Get安全性非常低,Post安全性较高。但是执行效率却比Post方法好
反驳:安不安全和Get和Post无关,与你加不加密有关,如果你不加密,两者都不安全