`
武佳兴
  • 浏览: 4646 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

99%的人都理解错了 HTTP 中 GET 与 POST 的区别

 
阅读更多

GET和POST是HTTP请求的两种基本方法,要说它们的区别,接触过WEB开发的人都能说出一二。

 

最直观的区别就是GET把参数包含在URL中,POST通过request body传递参数。

 

你可能自己写过无数个GET和POST请求,或者已经看过很多权威网站总结出的他们的区别,你非常清楚知道什么时候该用什么。

 

当你在面试中被问到这个问题,你的内心充满了自信和喜悦。

 

你轻轻松松的给出了一个“标准答案”:

  • GET在浏览器回退时是无害的,而POST会再次提交请求。

  • GET产生的URL地址可以被Bookmark,而POST不可以。

  • GET请求会被浏览器主动cache,而POST不会,除非手动设置。

  • GET请求只能进行url编码,而POST支持多种编码方式。

  • GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。

  • GET请求在URL中传送的参数是有长度限制的,而POST么有。

  • 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。

  • GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。

  • GET参数通过URL传递,POST放在Request body中。

 

(本标准答案参考自w3schools)

 

“很遗憾,这不是我们要的回答!”
 


 

请告诉我真相。。。

 

如果我告诉你GET和POST本质上没有区别你信吗?

让我们扒下GET和POST的外衣,坦诚相见吧!

 


 

 GET和POST是什么?HTTP协议中的两种发送请求的方法。

 

HTTP是什么?HTTP是基于TCP/IP的关于数据如何在万维网中如何通信的协议。

 

HTTP的底层是TCP/IP。所以GET和POST的底层也是TCP/IP,也就是说,GET/POST都是TCP链接。GET和POST能做的事情是一样一样的。你要给GET加上request body,给POST带上url参数,技术上是完全行的通的。

 

那么,“标准答案”里的那些区别是怎么回事?

 

在我大万维网世界中,TCP就像汽车,我们用TCP来运输数据,它很可靠,从来不会发生丢件少件的现象。

 

但是如果路上跑的全是看起来一模一样的汽车,那这个世界看起来是一团混乱,送急件的汽车可能被前面满载货物的汽车拦堵在路上,整个交通系统一定会瘫痪。为了避免这种情况发生,交通规则HTTP诞生了。

 

HTTP给汽车运输设定了好几个服务类别,有GET, POST, PUT, DELETE等等,HTTP规定,当执行GET请求的时候,要给汽车贴上GET的标签(设置method为GET),而且要求把传送的数据放在车顶上(url中)以方便记录。

 

如果是POST请求,就要在车上贴上POST的标签,并把货物放在车厢里。当然,你也可以在GET的时候往车厢内偷偷藏点货物,但是这是很不光彩;也可以在POST的时候在车顶上也放一些数据,让人觉得傻乎乎的。HTTP只是个行为准则,而TCP才是GET和POST怎么实现的基本。

 

但是,我们只看到HTTP对GET和POST参数的传送渠道(url还是requrest body)提出了要求。“标准答案”里关于参数大小的限制又是从哪来的呢?



 
在我大万维网世界中,还有另一个重要的角色:运输公司。

 

不同的浏览器(发起http请求)和服务器(接受http请求)就是不同的运输公司。 虽然理论上,你可以在车顶上无限的堆货物(url中无限加参数)。但是运输公司可不傻,装货和卸货也是有很大成本的,他们会限制单次运输量来控制风险,数据量太大对浏览器和服务器都是很大负担。

 

业界不成文的规定是,(大多数)浏览器通常都会限制url长度在2K个字节,而(大多数)服务器最多处理64K大小的url。超过的部分,恕不处理。如果你用GET服务,在request body偷偷藏了数据,不同服务器的处理方式也是不同的,有些服务器会帮你卸货,读出数据,有些服务器直接忽略,所以,虽然GET可以带request body,也不能保证一定能被接收到哦。

 

好了,现在你知道,GET和POST本质上就是TCP链接,并无差别。但是由于HTTP的规定和浏览器/服务器的限制,导致他们在应用过程中体现出一些不同。

 

你以为本文就这么结束了?



 

我们的大BOSS还等着出场呢。。。

 

这位BOSS有多神秘?当你试图在网上找“GET和POST的区别”的时候,那些你会看到的搜索结果里,从没有提到他。他究竟是什么呢。。。

 

GET和POST还有一个重大区别,简单的说:

 

GET产生一个TCP数据包;POST产生两个TCP数据包。

 

长的说:

 

对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);

 

而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。

 

也就是说,GET只需要汽车跑一趟就把货送到了,而POST得跑两趟,第一趟,先去和服务器打个招呼“嗨,我等下要送一批货来,你们打开门迎接我”,然后再回头把货送过去。

 

因为POST需要两步,时间上消耗的要多一点,看起来GET比POST更有效。因此Yahoo团队有推荐用GET替换POST来优化网站性能。但这是一个坑!跳入需谨慎。为什么?

 

1. GET与POST都有自己的语义,不能随便混用。

 

2. 据研究,在网络环境好的情况下,发一次包的时间和发两次包的时间差别基本可以无视。而在网络环境差的情况下,两次包的TCP在验证数据包完整性上,有非常大的优点。

 

3. 并不是所有浏览器都会在POST中发送两次包,Firefox就只发送一次。

 

 

现在,当面试官再问你“GET与POST的区别”的时候,你的内心是不是这样的?

 



 
原文:http://web.jobbole.com/88068/

  • 大小: 6.4 KB
  • 大小: 310.3 KB
  • 大小: 8.2 KB
  • 大小: 336.2 KB
分享到:
评论

相关推荐

    面试 HTTP ,99% 的面试官都爱问这些问题1

    在面试中,理解HTTP和HTTPS的基本原理、它们的区别以及GET和POST方法的用法是非常重要的。此外,还需要掌握HTTP协议的其他方法,如PUT、DELETE、HEAD等,以及HTTP头信息的使用,这有助于深入理解Web通信的细节。同时...

    99、修改Post类的status属性1

    ### Symfony 5中Post类Status属性的修改与调整 #### 一、背景介绍 在进行Symfony项目的开发过程中,经常会遇到需要调整实体类属性的情况。在本篇内容中,我们将聚焦于一个具体的例子——如何修改`Post`类中的`...

    GET方法URL中传递中文参数乱码的解决方法

    在互联网应用中,GET方法是HTTP协议中一种常见的请求方式,用于从服务器获取资源。然而,当我们在GET请求的URL中直接传递包含中文字符的参数时,可能会遇到乱码问题。这是因为不同系统、浏览器和服务器对字符编码的...

    SCWCD 99.999%高命中率考古题

    3. **HTTP协议**:理解HTTP的工作原理,包括请求方法(GET、POST等)、状态码、头信息和cookies。 4. **Web容器**:如Tomcat、Jetty等,它们为Servlet和JSP提供运行环境。考生需要理解容器如何管理Servlet实例,...

    fax99webservice文档2.0.doc

    Fax99的传真接口基于RESTful架构,通过HTTP请求进行操作,支持GET、POST等多种请求方法。 6.1 传真的接口地址 接口地址通常是固定URL,如`https://api.fax99.com/fax`,开发者需要根据具体的操作调用相应的路径。 ...

    HTTP协议精解

    总结:HTTP协议精解涉及到的知识点包括HTTP协议的作用、版本差异、请求与响应的格式、GET和POST请求的使用场景、状态码的意义、消息头的作用以及HTTP的无状态性和缓存机制等。这些知识点对于理解网络通信、设计Web...

    HttpClient问题:The server failed to respond with a valid HTTP resp

    2. **服务器配置**:服务器可能存在配置错误,例如服务器端口没有打开,服务器应用程序崩溃,或者服务器不支持请求的方法(GET、POST等)。使用其他工具(如curl或浏览器)尝试访问同一URL,看是否能正常接收响应。 ...

    数据包分析工具 httpwatch+professional7.0.23_99带.lnc

    1. **请求和响应分析**:HTTPWatch可以详细展示每个HTTP请求的完整生命周期,包括方法(GET、POST等)、状态码(200、404等)、请求头和响应头内容,这对于排查服务器问题和优化请求响应时间至关重要。 2. **时间线...

    http传输与json解析

    在Web应用中,JSON(JavaScript Object Notation)作为一种轻量级的数据交换格式,因其易于人阅读和编写,同时也容易让机器解析和生成,而被广泛应用。JSON的数据结构主要由对象(键值对)和数组组成,与JavaScript...

    php和asp对象的等价关系

    ASP中,`Request.Form`和`Request.QueryString`分别用于获取POST和GET数据。PHP中,`$HTTP_POST_VARS`和`$HTTP_GET_VARS`数组对应这些数据,但现代PHP推荐使用`$_POST`和`$_GET`超全局数组,以提高安全性。 8)...

    C#winform调用webapi.rar

    5. **POST请求与Content-Type**:当上传JSON数据时,HTTP请求类型应为POST,请求头中的`Content-Type`应设为`application/json`,表示数据是JSON格式。 6. **错误处理**:在调用WebAPI时,应捕获可能出现的异常,...

    postman7.9 for mas/linux

    首先,Postman支持多种HTTP请求方法,如标题和标签中提到的POST、GET、PUT等。这些是Web服务交互中的基本操作: 1. **POST**:用于向服务器发送数据,通常用于创建新的资源。例如,当我们注册新用户或上传文件时,...

    java+web项目实战大全源码搜索引擎源码整理

    9. **RESTful API设计**:为了让前后端分离更彻底,项目可能通过RESTful API进行通信,需要理解HTTP方法(GET、POST、PUT、DELETE)以及状态码等。 10. **版本控制**:项目源码可能使用Git进行版本控制,理解分支...

    java教程习题与答案内附期末试卷一份

    - HTTP协议:理解GET和POST请求。 8. **反射**: - Class类:动态获取类的信息,创建对象,调用方法等。 - 构造器和方法的反射调用:如何在运行时动态执行代码。 9. **JavaFX和Swing**: - 创建图形用户界面...

    cj99.js:cj99-jquery-utils

    - AJAX请求:为了进行异步数据交换,cj99.js可能会封装XMLHttpRequest,提供更简洁的接口来进行GET、POST等HTTP请求。 - 兼容性处理:考虑到浏览器之间的差异,cj99.js可能包含了对旧版本浏览器的兼容性支持,确保在...

    httpMan.zip_71337aacom_httpmam_httpman_www.205555.com_www,205555

    HTTPMan支持RESTful模式,意味着它可以方便地处理各种HTTP方法(如GET、POST、PUT、DELETE),并能优雅地处理URL路径、查询参数以及请求和响应体中的数据。通过XStream和Gson,HTTPMan能够轻松地将Java对象转换为...

    http request

    HTTP请求通常由四个主要部分组成:方法(GET、POST、PUT、DELETE等)、URL(统一资源定位符,指定要访问的资源)、HTTP版本号和一个可选的请求头部,用于传递额外的信息。 描述中提到的是iOS平台上的HTTP请求实现,...

    Go-slapper简单的负载测试工具具有实时更新的请求时序直方图

    此外,还可以定制HTTP请求,包括方法(GET、POST等)、URL、Header和请求体,以满足特定的测试需求。 在压缩包`slapper-master`中,包含了Go-slapper的源代码和其他相关文件。你可以通过阅读源码了解其工作原理,并...

    spring-restful

    2. **HTTP方法(GET、POST、PUT、DELETE)**:RESTful服务中的每个资源都有一个唯一的URI,不同的HTTP方法对应于对资源的不同操作。GET用于获取资源,POST用于创建新资源,PUT用于更新现有资源,DELETE用于删除资源。 ...

    java面试宝典2012

    2、HTTP请求的GET与POST方式的区别 93 3、解释一下什么是servlet; 93 4、说一说Servlet的生命周期? 93 5、Servlet的基本架构 94 6、SERVLET API中forward() 与redirect()的区别? 94 7、什么情况下调用doGet()和...

Global site tag (gtag.js) - Google Analytics