HTTP请求的基本方法:GET和POST
HTTP是基于TCP/IP的关于数据如何在万维网中如何通信的协议。
GET和POST本质上就是TCP链接,并无差别。但是由于HTTP的规定和浏览器/服务器的限制,导致他们在应用过程中体现出一些不同。
GET产生一个TCP数据包;POST产生两个TCP数据包。
推荐阅读:99%的人都理解错了HTTP中GET与POST的区别,HTTP协议中GET和POST方法的区别
1. GET与POST都有自己的语义,不能随便混用。
GET的语义是请求获取指定的资源。
POST的语义是根据请求负荷(报文主体)对指定的资源做出处理,具体的处理方式视资源类型而不同。
2. 据研究,在网络环境好的情况下,发一次包的时间和发两次包的时间差别基本可以无视。而在网络环境差的情况下,两次包的TCP在验证数据包完整性上,有非常大的优点。
3. 并不是所有浏览器都会在POST中发送两次包,Firefox就只发送一次。
get:用于获取数据(如:浏览贴子),把数据放在url(网址)里来提交,安全性低、容量小(<2k),便于分享(商品地址和url有关),适合获取,且会缓存;
post:用于上传数据(如:用户注册,表单提交),把数据放在不是url的地方提交,安全性一般、容量几乎无限,更适合上传(图片等)。
get和post 只是发送机制不同,并不是一个取一个发!
(本标准答案参考自w3schools)
GET在浏览器回退时是无害的,而POST会再次提交请求。
GET产生的URL地址可以被Bookmark,而POST不可以。
GET请求会被浏览器主动cache,而POST不会,除非手动设置。
GET请求只能进行url编码,而POST支持多种编码方式。
GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
GET请求在URL中传送的参数是有长度限制的,而POST么有。(HTTP协议并没有限制URI的长度,具体的长度是由浏览器和系统来约束的)
对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
GET参数通过URL传递,POST放在Request body中。
get方法被大量应用的主要原因是因为其工作效率高。
get请求有如下特性:它会将数据添加到URL中,通过这种方式传递到服务器,通常利用一个问号?代表URL地址的结尾与数据参数的开端,后面的参数每一个数据参数以“名称=值”的形式出现,参数与参数之间利用一个连接符&来区分。
post请求有如下特性:数据是放在HTTP主体中的,其组织方式不只一种,有&连接方式,也有分割符方式,可隐藏参数,传递大批数据,比较方便。