面试必备:GET和POST的用法和区别

版权声明一:本文为博主原创文章,转载请附上原文出处链接和本声明。
版权声明二:本网站的所有作品会及时更新,欢迎大家阅读后发表评论,以利作品的完善。
版权声明三:对不遵守本声明或其他违法、恶意使用本网内容者,保留追究其法律责任的权利。

一、有何不同

一、w3school标准答案

面试必备:GET和POST的用法和区别_第1张图片1.jpg

注意,并不是说标准答案有误,上述区别在大部分浏览器上是存在的,因为这些浏览器实现了 HTTP 标准。

二、从标准上来看

  • GET 用于获取信息,是无副作用的,是幂等的,且可缓存 。
  • POST 用于修改服务器上的数据,有副作用,非幂等,不可缓存。
    面试必备:GET和POST的用法和区别_第2张图片2.jpg

三、GET 方法的长度限制是怎么回事?

网络上都会提到浏览器地址栏输入的参数是有限的。

首先说明一点,HTTP 协议没有 Body 和 URL 的长度限制,对 URL 限制的大多是浏览器和服务器的原因。

浏览器原因就不说了,服务器是因为处理长 URL 要消耗比较多的资源,为了性能和安全(防止恶意构造长 URL 来攻击)考虑,会给 URL 长度加限制。

四、POST 方法比 GET 方法安全?

有人说POST 比 GET 安全,因为数据在地址栏上不可见。

然而,从传输的角度来说,他们都是不安全的,因为 HTTP 在网络上是明文传输的,只要在网络节点上捉包,就能完整地获取数据报文。

要想安全传输,就只有加密,也就是 HTTPS。

五、POST 方法会产生两个TCP数据包?

有些文章中提到,post 会将 header 和 body 分开发送,先发送 header,服务端返回 100 状态码再发送 body。

HTTP 协议中没有明确说明 POST 会产生两个 TCP 数据包,而且实际测试(Chrome)发现,header 和 body 不会分开发送。

所以,header 和 body 分开发送是部分浏览器或框架的请求方法,不属于 post 必然行为。

我是阿康同学,在北京奋斗的Java软件工程师。
爱生活;爱健身;爱篮球,喜欢曼巴精神。
人生格言:「认真洗脸,多读书按时睡,少食多餐继续善良保持爱。」

 

下面是我的公众号二维码图片,欢迎关注。

面试必备:GET和POST的用法和区别_第3张图片阿康同学.jpg

你可能感兴趣的:(面试必备:GET和POST的用法和区别)