关于HTTP中GET与POST的区别

GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一二。web

看似很简单,实际上是一道送命题浏览器

      “标准答案”:安全

  • GET在浏览器回退时是无害的,而POST会再次提交请求。
  • GET产生的URL地址能够被Bookmark,而POST不能够。
  • GET请求会被浏览器主动cache,而POST不会,除非手动设置。
  • GET请求只能进行url编码,而POST支持多种编码方式。
  • GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
  • GET请求在URL中传送的参数是有长度限制的,而POST没有

 

HTTP 协议 未规定 GET 和POST的长度限制,服务器

GET的最大长度显示是由于 浏览器和 web服务器限制了 URI的长度网络

 

IE 和 Safari 浏览器 限制 2k并发

Opera 限制4k性能

Firefox 限制 8k(很是老的版本 256byte)优化

若是超出了最大长度,大部分的服务器直接截断,也有一些服务器会报414错误。网站

 

 

  • 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
  • GET比POST更不安全,由于参数直接暴露在URL上,因此不能用来传递敏感信息。
  • GET参数经过URL传递,POST放在Request body中

 

GET和POST是HTTP协议中的两种发送请求的方法。编码

HTTP是基于TCP/IP的关于数据如何在万维网中如何通讯的协议。

HTTP的底层是TCP/IP

GET和POST本质上就是TCP连接,并没有差异。可是因为HTTP的规定和浏览器/服务器的限制,致使他们在应用过程当中体现出一些不一样

HTTP对GET和POST参数的传送渠道(url仍是requrest body)提出了要求

数据量太大对浏览器和服务器都是很大负担。业界不成文的规定是,(大多数)浏览器一般都会限制url长度在2K个字节,而(大多数)服务器最多处理64K大小的url。超过的部分,恕不处理。若是你用GET服务,在request body偷偷藏了数据,不一样服务器的处理方式也是不一样的,有些服务器会帮你卸货,读出数据,有些服务器直接忽略,因此,虽然GET能够带request body,也不能保证必定能被接收到。

 

GET和POST还有一个重大区别:

GET产生一个TCP数据包;POST产生两个TCP数据包。

对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);

而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。

 

由于POST须要两步,时间上消耗的要多一点,看起来GET比POST更有效。所以Yahoo团队有推荐用GET替换POST来优化网站性能。但这是一个坑!跳入需谨慎。为何?

1. GET与POST都有本身的语义,不能随便混用。

2. 据研究,在网络环境好的状况下,发一次包的时间和发两次包的时间差异基本能够无视。而在网络环境差的状况下,两次包的TCP在验证数据包完整性上,有很是大的优势。

3. 并非全部浏览器都会在POST中发送两次包,Firefox就只发送一次。

相关文章
相关标签/搜索