【网络面试题】请说下GET和POST的区别?

共 1239字,需浏览 3分钟

 ·

2021-03-24 16:59









前端猎手
 链接每一位开发者,让编程更有趣儿!
关注



当面试官问起GETPOST的区别时,我们要先确定,这里的GETPOST是基于什么前提的?

如果什么前提都没有,也就是不用任何规范限制的话,我们只考虑语法来说,这两个方式是没有任何区别的,只有名字不一样。

如果是基于RFC规范的,那么问题就又来了。是基于RFC理论的,还是基于具体的实现的。

(1)如果是基于RFC理论的,我们称这个为Specification(规范)。那么GET和POST是具有相同的语法,但是不具备相同的语义,GET方式用作获取信息POST方式用作发送信息

(2)如果是基于RFC的具体实现的,我们称之为implementation(实施)。其实要区分是具体的哪一种实现。我们通常默认指的是浏览器实现的RFC。当然不止浏览器,我们任何人都可以设计一个HTTP协议的接口,使用RFC规范,当然这些是我们不用考虑的,因为并不通用。

所以我们只需要考虑浏览器实现的RFC,或者说Web环境下的RFC。这个前提下的答案,就是我们最常见的那些。我就简单的列举在下面了~

  • GET的数据在 URL 中对所有人都是可见的。POST的数据不会显示在 URL 中。

  • GET对数据长度有限制,当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。POST无限制。

  • GET可收藏为书签,POST不可收藏为书签。

  • GET后退按钮/刷新无影响,POST数据会被重新提交(浏览器应该告知用户数据会被重新提交)。

  • GET编码类型application/x-www-form-url,POST编码类型encodedapplication/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。

  • GET历史参数会保留在浏览器历史中。POST参数不会保存在浏览器历史中。

  • GET只允许 ASCII 字符。POST没有限制。也允许二进制数据。

  • 与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。在发送密码或其他敏感信息时绝不要使用 GET !POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。

以上这些点都是我们常见的,还有一些我们不常见的,比如GET请求只会有一次TCP连接,而POST请求会有两次TCP连接。

所以在我们不要认为GET和POST请求有什么区别是一个很简单的问题哦~很多简单的问题背后都有着很复杂的背景。


 📌 最后


当然也可以关注我的公众号:前端猎手,或是添加我的微信wKavin私底下进行交流。

浏览 23
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报