本文来源于微信公众号:后厂技术官。文章链接:尴尬!99%的人都理解错了 HTTP 中 GET 与 POST 的区别 如有侵权,联系必删
GET和POST是HTTP协议中的两种发送请求的方法,他们的区别:
“标准答案”:
- GET在浏览器回退时是无害的,而POST会再次提交请求。
- GET产生的URL地址可以被Bookmark,而POST不可以。
- GET请求会被浏览器主动cache,而POST不会,除非手动设置。
- GET请求只能进行url编码,而POST支持多种编码方式。
- GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
- GET请求在URL中传送的参数是有长度限制的,而POST么有。
- 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
- GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
- GET参数通过URL传递,POST放在Request body中。
但实际上:
GET和POST是HTTP协议中的两种发送请求的方法,HTTP是基于TCP/IP的关于数据如何在万维网中通信的协议。
GET和POST能做相同的事
- HTTP底层是TCP/IP,所以GET和POST的底层也是TCP/IP,也就是说,GET和POST都是TCP链接,他俩能做的事是一样的。
HTTP是一种规范,TCP是GET和POST怎么实现的基本。
HTTP规定GET把请求参数放到url中,POST把请求参数放到request.body中
- 业界有个不成文的规定,大多数浏览器会限制url长度在2k个字节,而大多数服务器最多处理64k的url,找过的部分不处理。GET可以把参数放到request.body中,但不同的服务器处理方式不同,有的会读出数据,有的则直接忽略。
GET产生一个TCP数据包;POST产生两个TCP数据包
- GET请求,浏览器会把http header和data一并发送出去,服务器响应200返回数据;
- POST请求,浏览器先发送http header,服务器响应100 continue,浏览器再发送data,服务器响应200 OK返回数据。
POST需要两步,GET只需一步。这样看来GET好像比POST更有效,但GET不能替代POST来优化网站性能。原因是:
- GET和POST都有自己的语义,不能随便混用;
- 经研究,网络环境好时发一次和两次的时间差别基本可以忽略;而在网络环境差时两次包的TCP在验证数据包完整性上有非常大的优点;
- 并不是所有浏览器都会在POST中发送两次包,Firefox就只发送一次
综上所述:
- GET和POST在本质上没有区别,都是基于TCP来进行发送请求的实现。
- 但由于HTTP协议,使GET和POST在使用上有区别:
- GET把请求参数放到url中,POST把请求参数放到request.body中
- GET产生一个TCP数据包;POST产生两个TCP数据包