GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一二。web
看似很简单,实际上是一道送命题浏览器
“标准答案”:安全
HTTP 协议 未规定 GET 和POST的长度限制,服务器
GET的最大长度显示是由于 浏览器和 web服务器限制了 URI的长度网络
IE 和 Safari 浏览器 限制 2k并发
Opera 限制4k性能
Firefox 限制 8k(很是老的版本 256byte)优化
若是超出了最大长度,大部分的服务器直接截断,也有一些服务器会报414错误。网站
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就只发送一次。