为什么POST请求比GET请求慢?

为什么POST请求比GET请求慢?

​编辑

哲思青年显生

分享软件测试知识

​关注

1、两者区别

①数据量

get从指定资源请求数据,请求内容直接拼接在url后面,数据长度有限制

post将需要处理的数据提交到指定资源,被处理数据放在http请求体中(body体),数据长度不受限制

②安全性

get请求数据放在url中,信息是明文显示,安全性不高

post请求数据不会作为url的一部分进行明文展示,不会被缓存、保存在服务器日志、以及浏览器浏览记录中

③数据类型

get对数据类型有限制,只允许ASCII字符

post对数据类型没有限制,也允许二进制数据

④速度

get请求速度快,post请求速度慢(一般做数据查询时用Get方式;做数据添加、修改或删除时用Post方式)

2、post请求为什么比get请求慢?

①post请求包含更多的请求头

post请求体(body)中包含的数据比get大

②post请求过程更复杂

post在真正接受数据之前,会先将请求头发送给服务器进行确认,然后才真正发送数据

post请求的过程:

a.浏览器请求tcp连接(第一次握手)

b.服务器答应进行tcp连接(第二次握手)

c.浏览器确认,并发送post请求头(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)

d.服务器返回100 continue响应

e.浏览器开始发送数据

f.服务器返回200 ok响应

get请求的过程:

a.浏览器请求tcp连接(第一次握手)

b.服务器答应进行tcp连接(第二次握手)

c.浏览器确认,并发送get请求头和数据(第三次握手,这个报文比较小,所以http会在此时进行第一次数据发送)

d.服务器返回200 ok响应

③get会将数据缓存起来,而post不会

可以做个简短的测试,使用ajax采用get方式请求静态数据(比如html页面,图片)的时候,如果两次传输的数据相同,第二次以后耗费的时间将在10ms以内(chrome测试),而post每次耗费的时间都差不多……

经测试,chrome下和firefox下如果检测到get请求的是静态资源,则会缓存,如果是数据,则不缓存,但是IE...

④post不能进行管道化传输

http权威指南中是这样说的:http在的一次会话需要先建立tcp连接(大部分是tcp,但是其他安全协议也是可以的),然后才能通信,如果每次连接都只进行一次http会话,那这个连接过程占的比例太大了!

于是出现了持久连接:在http/1.0+中是connection首部中添加keep-alive值,在http/1.1中是在connection首部中添加persistent值,当然两者不仅仅是命名上的差别,http/1.1中,持久连接是默认的,除非显示在connection中添加close,否则持久连接不会关闭,而http/1.0+中则恰好相反,除非显示在connection首部中添加keep-alive,否则在接收数据包后连接就断开了。

出现了持久连接还不够,在http/1.1中,还有一种称为管道通信的方式进行速度优化:把需要发送到服务器上的所有请求放到输出队列中,在第一个请求发送出去后,不等到收到服务器的应答,第二个请求紧接着就发送出去,但是这样的方式有一个问题:不安全,如果一个管道中有10个连接,在发送出9个后,突然服务器告诉你,连接关闭了,此时客户端即使收到了前9个请求的答复,也会将这9个请求的内容清空,也就是说,白忙活了……

此时,客户端的这9个请求需要重新发送。

这对于幂等请求还好(比如get,多发送几次都没关系,每次都是相同的结果),如果是post这样的非幂等请求(比如支付的时候,多发送几次就惨了),肯定是行不通的。

所以,post请求不能通过管道的方式进行通信!

   很有可能,post请求需要重新建立连接,这个过程不跟完全没优化的时候一样了么?

所以,在可以使用get请求通信的时候,不要使用post请求,这样用户体验会更好,当然,如果有安全性要求的话,post会更好。

管道化传输在浏览器端的实现还需考证,貌似默认情况下大部分浏览器(除了opera)是不进行管道化传输的,除非手动开启!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值