前言:很多小伙伴对于get和post都是浅层次的理解。这篇文章将带你从通俗易懂的语言上深入的了解get和post。
一,什么是Get/Post?
在了解get和post之前,我们要先了解TCP/IP和http。简单来说,TCP/IP是网络架构,TCP/IP是五层网络架构(区分于OSI七层架构),TCP/IP自上而下分为应用层,传输层,网络层,数据链路层,物理层。更深入的知识这里就不涉及,有兴趣可以自己去了解。Http是位于应用层的协议,TCP位于传输层(区别于UDP),IP是位于网络层的。简单来说,Http是基于TCP/IP的一种通信协议(超文本传输协议,所有www都必须遵循这个协议,你所看到的网页都是基于这个协议)。
那初步知道了TCP/IP的网络模型和Http后,我们来进一步了解get和post。
get和post是http上的两种请求方式,其本质是TCP链接,两者并无差别。(请求方式:Get,Post,Put,Delect)(标准六种:get,post,put,delect,head,options)
二·,GET/POST误解
传统上,很多人认为get是通过url传输数据,post是通过response body传输数据;get的传参大小是2K,post是64K;post比get安全等等,这些都是错误的理解。
从上面的解释,我们已经知道Get和post其实就是TCP是两种链接。通过一定的技术手段,get也可以通过response body传参,post也可以通过url传参。
举个例子:在一条公路上,跑车很多运输货品的车辆,这些车辆就好比是TCP,同时,这些车辆有的运输多,有的运输少,因为没有交通规则往往会导致公路堵塞,所以这时就有了交通规则----HTTP,此时服务端和客户端就像是两个公司,一个提供货物,一个接收货物;而get就像是把货物放在车的上面,post就是放在货物箱里面。按理来说,你要是把货物放在上面的车辆在筛一些货物放在里面,或者是把货物箱里面的货物拿出来放在车上,都是可以的。(这里是引用知乎的解释)
三,GET和POST的区别
其实两者在tcp传输中并无不同。
那说了这么多,get和post的区别到底是什么呢?
get会产生一个TCP数据包,POST会产生两个TCP数据包。
get会发送http header和data给服务端,服务端返回一个200,请求成功。
post会先发送http header给服务端,告诉服务端等一下会有数据过来,服务端返回100,告诉客户端我已经准备接收数据,post在发送一个data给服务端,服务端返回200,请求成功。
但是上面所说的post会比get多一个tcp包其实不太严谨。多发的那个expect 100 continue header报文,是由客户端对http的post和get的请求策略决定的,目的是为了避免浪费资源,如带宽,数据传输消耗的时间等等。所以客户端会在发送header的时候添加expect 100去探探路,如果失败了就不用继续发送data,从而减少了资源的浪费。所以是否在发送一个包取决了客户端的实现策略,和get/post并没什么关系。有的客户端比如fireFox就只发送一个包。
(注:以上感谢Eurus和峰哥的差错修改)