计算机网络面试更重要健康生活

给你不一样的答案--GET和POST的区别

2016-10-05  本文已影响68人  峰峰小

大家网上随便一搜,一大堆关于GET和POST这两种请求方式区别的讲解,比如

然而,,,,,,,,,,,,,,,,,,,,,,
如果你也接受了这样的结果,那估计可以考虑转行了!

先不要打我,让我给你解释完再打:

1、GET和POST与数据如何传递没有关系
GET和POST是由HTTP协议定义的。在HTTP协议中,Method和Data(URL, Body, Header)是正交的两个概念,也就是说,使用哪个Method与应用层的数据如何传输是没有相互关系的。

HTTP没有要求,如果Method是POST数据就要放在BODY中。也没有要求,如果Method是GET,数据(参数)就一定要放在URL中而不能放在BODY中。

那么,网上流传甚广的这个说法是从何而来的呢?在HTML标准中,找到了相似的描述。这和网上流传的说法一致。但是这只是HTML标准对HTTP协议的用法的约定。怎么能当成GET和POST的区别呢?

而且,现代的Web Server都是支持GET中包含BODY这样的请求。虽然这种请求不可能从浏览器发出,但是现在的Web Server又不是只给浏览器用,已经完全地超出了HTML服务器的范畴了。

2、HTTP协议对GET和POST都没有对长度的限制
HTTP协议明确地指出了,HTTP头和Body都没有长度的要求。而对于URL长度上的限制,有两方面的原因造成:

3、安全不安全和GET、POST没有关系
安全这东西是相对的,网上有个小段子,大家应该可以体会出这个说法多么的可笑。

觉得POST数据比GET数据安全的人会说:

“防君子不防小人;中国小白多,能防小白用户就行了。”
“哼,”我不以为然,“那你怎么不说,URL参数都Encode过了,或是Base64一下,小白也看不懂啊。”
那人反驳道,“Encode太简单了,聪明点儿的小白很容易就可以Decode并修改掉。”
我笑道,“五十步笑百步耳,再聪明点儿的小白还会截包并重发呢,Opera就有这功能。”
那人阴险地祭出神器——最终解释权,说,“这个不算小白。”

(⊙o⊙)


总结

所以对于GET和POST的理解,是纯粹地来源于HTTP协议。他们只有一点根本区别,简单点儿说,一个用于获取数据(GET),一个用于修改数据(POST)。

上一篇 下一篇

猜你喜欢

热点阅读