目录
这是一个比较常见的问题了......
GET:从指定资源请求数据。
POST:向指定资源提交数据。
●POST和GET的区别(常规回答):
1.GET在浏览器回退/刷新时是无害的,而POST的数据会被重新提交。
2.GET产生的URL地址可以被收藏为,而POST不可以。
3.GET请求会被浏览器主动缓存,而POST不会,除非手动设置。
4.GET请求只能进行url编码,而POST支持多种编码方式。
5.GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
6.GET请求在URL中传送的参数是有长度限制的(URL最大长度是2048个字符),而POST没有限制。
7.对参数的数据类型,GET只接受ASCII字符,而POST没有限制(也允许二进制数据)。
8.GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
9.GET的数据在URL中对所有人都可见,但是POST不是。
●事实上,POST和GET本质上是没有区别的,只是他们的报文格式不同。
●POST和GET是什么?
是HTTP协议中的两种请求方法。HTTP是基于TCP/IP的数据如何在网络中通信的协议,HTTP的底层是TCP/IP,也就是说,GET和POST的底层都是TCP/IP,所以在传输上他们是没有区别的。
●报文格式:
1.不带参数时:请求报头除了请求方法其他都相同。
//POST请求请求首行
POST /url HTTP 1.0 \r\n
//GET请求请求首行
GET /url HTTP 1.0 \r\n
2.带参数:GET请求将参数放在URL中,POST请求将参数放在正文中。
//POST请求请求报文
POST /index.htm?uid=1&age=10 HTTP 1.0 \r\n
....请求报头....
uid=1&age=10
//GET请求请求首行
GET /index.htm?uid=1&age=10HTTP 1.0 \r\n
3.GET和POST的本质都是TCP连接,那么将POST的参数放在URL或者将GET的参数放在正文中也是可以的。
●上述常规回答说GET的参数有限制?
HTTP协议并没有对URL和正文长度的限制,但是浏览器和服务器有啊,浏览器URL太长也太难消化了,服务器处理的URL过长时很费资源的,因此加了限制。
●上述常规回答说POST比GET更安全?
安全只是相对的,从传输的角度看,他们都不安全,因为它们属于HTTP协议,HTTP明文传输本就不是安全的,要想绝对安全,只有用HTTPS了。
●网上有结论说POST请求会产生两个数据包?(有待考证)
GET产生一个TCP数据包;POST产生两个TCP数据包。
对于GET方式的请求,浏览器会把 header和data一并发送出去,服务器响应200;
对于POST,浏览器先发送header,服务器响应100 ,浏览器再发送data,服务器响应200 ok。
但是,头部和正文分开发送只是部分浏览器的请求方法,并不是所有的浏览器的POST都这样。
●GET和POST选择哪个?
私密性的信息请求使用POST。
查询信息和可以想要通过url分享的信息使用GET。