【每日一题】get和post的区别
人生苦短,总需要一点仪式感。比如学前端~
get 和 post
get参数通过URL传递方式,post放在Request body中。 get请求会被浏览器主动缓存(cache),而post不会,除非手动设置。(缓存一般只适用于那些不会更新服务端数据的幂等请求。 get请求参数会被完整保留在浏览器历史记录里,而post中的参数不会被保留。 get请求中有非ASCII字符,会在请求之前进行转码,POST不用,因为post在Request body中,通过MIME,也就可以传输非ASCII字符。 一般我们在浏览器输入一个网址访问网站都是get请求 HTTP的底层是TCP/IP。HTTP只是个行为准则,而TCP才是get和post怎么实现的基本。get/post都是TCP链接。get和post能做的事情是一样一样的。但是请求的数据量太大对浏览器和服务器都是很大负担。所以业界有了不成文规定,(大多数) 浏览器通常都会限制url长度在2K个字节,而(大多数)服务器最多处理64K大小的url。 get产生一个TCP数据包; post产生两个TCP数据包。对于get方式的请求,浏览器会把http header和data一并发送出去,服务器响应200 (返回数据) ;而对于post,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok (返回数据) 在网络环境好的情况下,发一次包的时间和发两次包的时间差别基本可以无视。而在网络环境差的情况下,两次包的TCP在验证数据包完整性上,有非常大的优点。但并不是所有浏览器都会在post中发送两次包,Firefox就只发送一次。
幂等(idempotent)
如果一个方法重复执行多次,产生的效果是一样的。我们就将其定义为幂等的。
比如:
get请求: 通常用于获取数据,执行多次和执行一次得到的结果一样(不考虑数据被其他入口改动)。 put请求:如果两个请求相同,后一个请求会把第一个请求覆盖掉。(所以PUT用来改资源) post请求:后一个请求不会把第一个请求覆盖掉。(所以post用来增加资源)
让我们一起携手同走前端路!
关注公众号回复【加群】即可
评论