前言
说到get请求和post请求的区别,最直观的感受是get请求把参数放在url中,post请求是通过request body传递参数。但事实上并非如此。
一、get请求和post请求的区别
我们先来具体列举他们之间的区别:
- GET请求在URL中传送的参数是有长度限制的,而POST没有。
- 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
- GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
- GET参数通过URL传递,POST放在Request body中。
- GET请求只能进行url编码,而POST支持多种编码方式。
- GET在浏览器回退时是无害的,而POST会再次提交请求。
- GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
实际上,他们的本质上并没有区别,get请求也可以通过request body进行数据传输,post请求也可以通过url进行数据传输。那他们为什么会有以上这些‘ 明文规定’的区别呢?
二、get请求和post请求的本质
get和post是什么?要回答这个问题,首先我们得知道http协议底层是tcp/ip协议。所以get和post底层也是tcp/ip协议。即tcp链接。get和post能做的事情是一样的。给get请求加上request body,给post加上url参数,技术上是完全可行的。
其实,在互联网的世界里,数据的传输工具就像是汽车,汽车用来传输数据,各种汽车之间有不同的类型,也就是GET, POST, PUT, DELETE等等。http规定,执行get请求时要给汽车车顶贴上get标签,并且把传送的数据放在车顶上(即url所以它是不安全的裸露的)。而post请求就是要给汽车贴上post的标签,并要求数据在存放在车内进行传输。
以上说的只是传输过程,最最主要的还是发送方和接收方给出了限制。其实就是我们的浏览器(发起http请求)和服务器(接受http请求)。浏览器和服务器限制了get和post的传输规则。一旦在传输数据的过程中超出或违法他们的规定,浏览器和服务器有权拒绝或忽略这些请求。(大多数)浏览器通常都会限制url长度在2K个字节,而(大多数)服务器最多处理64K大小的url。超过的部分,恕不处理。所以,虽然GET可以带request body,也不能保证一定能被接收到哦。
三、数据包的不同
简单的说:GET产生一个TCP数据包;POST产生两个TCP数据包。也就是说,GET只需要汽车跑一趟就把货送到了,而POST得跑两趟,第一趟,先去和服务器打个招呼“嗨,我等下要送一批货来,你们打开门迎接我”,然后再回头把货送过去。
但也要分环境:
在网络环境好的情况下,发一次包的时间和发两次包的时间差别基本可以无视。而在网络环境差的情况下,两次包的TCP在验证数据包完整性上,有非常大的优点。
且并不是所有浏览器都会在POST中发送两次包,Firefox就只发送一次。