最近看了一些同学的面经,发现无论什么技术岗位,还是会问到 get 和 post 的区别,而搜索出来的答案并不能让我们装得一手好逼,那就让我们从 HTTP 报文的角度来撸一波,从而搞明白他们的区别。
2、标准答案
在开撸之前吗,让我们先看一下标准答案长什么样子 w3school: GET 对比 POST。标准答案很美好,但是在面试的时候把下面的表格甩面试官一脸,估计会装逼不成反被*。
后退按钮/刷新 | 无害 | 数据会被重新提交(浏览器应该告知用户数据会被重新提交)。 |
书签 | 可收藏为书签 | 不可收藏为书签 |
缓存 | 能被缓存 | 不能缓存 |
编码类型 | application/x-www-form-urlencoded | application/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。 |
历史 | 参数保留在浏览器历史中。 | 参数不会保存在浏览器历史中。 |
对数据长度的限制 | 是的。当发送数据时,GET *** 向 URL 添加数据;URL 的长度是受限制的(URL 的更大长度是 2048 个字符)。 | 无限制。 |
对数据类型的限制 | 只允许 ASCII 字符。 | 没有限制。也允许二进制数据。 |
安全性 | 与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。在发送密码或其他敏感信息时绝不要使用 GET ! | POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。 |
可见性 | 数据在 URL 中对所有人都是可见的。 | 数据不会显示在 URL 中。 |
注意,并不是说标准答案有误,上述区别在大部分浏览器上是存在的,因为这些浏览器实现了 HTTP 标准。但是,前面列举的只是浏览器实现上的区别,而不是 get 和 post 的本质区别。
3、GET 和 POST 报文上的区别
先下结论,GET 和 POST *** 没有实质区别,只是报文格式不同。
GET 和 POST 只是 HTTP 协议中两种请求方式,而 HTTP 协议是基于 TCP/IP 的应用层协议,无论 GET 还是 POST,用的都是同一个传输层协议,所以在传输上,没有区别。
报文格式上,不带参数时,更大区别就是之一行 *** 名不同
POST *** 请求报文之一行是这样的 POST /uri HTTP/1.1 \r\n
GET *** 请求报文之一行是这样的 GET /uri HTTP/1.1 \r\n
是的,不带参数时他们的区别就仅仅是报文的前几个字符不同而已
带参数时报文的区别呢? 在约定中,GET *** 的参数应该放在 url 中,POST *** 参数应该放在 body 中
举个例子,如果参数是 name=chengqm, age=22。
GET *** 简约版报文是这样的
GET /index.php?name=qiming.c&age=22 HTTP/1.1
Host: localhost
POST *** 简约版报文是这样的
POST /index.php HTTP/1.1
Host: localhost
Content-Type: application/x-www-form-urlencoded
name=qiming.c&age=22
现在我们知道了两种 *** 本质上是 TCP 连接,没有差别,也就是说,如果我不按规范来也是可以的。我们可以在 URL 上写参数,然后 *** 使用 POST;也可以在 Body 写参数,然后 *** 使用 GET。当然,这需要服务端支持。
海子为何卧轨(诗人海子为何卧轨自杀)1989年3月26日,海子在山海关至龙营中间的铁路上卧轨。他选了一个列车上坡的道路。他死前好几天也没有进食。他带在的身上的遗嘱简易写着,我的死与所有人不相干,遺...
蜈支洲岛位于三亚市北部的海棠湾内。距三亚市中心30公里、三亚凤凰国际机场38公里,紧邻海南东线高速公路,交通便利快捷。来三亚旅游的人基本上不会去市中心,市中心没景点嘛,也不可能坐公交,刚坐完飞机,就和...
爱奇艺《奇葩说》第四季即将在本周五、周六日两集连播。本季的《奇葩说》除了马东变为导师,并请来何炅主持之外,导师阵容上新增罗振宁,张泉灵。之前《奇葩大会》上的的导师高晓松哪去了?不少网友很好奇高晓松为什...
电暖气有辐射吗(电暖气使用注意事项)电暖气现在很多朋友的家里都有,有不少朋友会担心电暖气的危害,辐射就是其中的一点。那电暖气有辐射吗?电暖气使用要注意些什么样的事情吗?下面让小编来给大家讲讲吧。...
美赞臣奶粉因为地区不同的原因有不同地区的版本,很多代购经常能买到的是香港版的美赞臣,下面友谊长存的小编就来说说:香港美赞臣3段奶粉怎么样 香港美赞臣3段奶粉。 香港美赞臣3段奶粉怎么样 儿子出生...
关于组织面临的威胁,Verizon数据泄露调查报告(DBIR)提供了重要的观点。本次DBIR基于41686起安全事件和2013起数据泄露的真实数据,数据由全球86个国家的公共实体或私有实体的共计7...