GET和POST

详解HTTP中GET和POST的区别
Http协议定义了客户端与服务器交互的不同方法,最基本的方法有4种,分别是GET,POST,PUT,DELETE。分别对这个资源的查,改,增,删4个操作。
GET一般用于获取/查询资源信息,而POST一般用于更新资源信息。

比较GET和POST
GET和POST

关于其误区:

  • 误区一:POST可以比GET提交更多更长的数据?
    由于使用GET方法提交数据时,数据会以&符号作为分隔符的形式,在URL后面添加需要提交的参数,有人就会说了,浏览器地址栏输入的参数是有限的,而POST不用再地址栏输入,所以POST就比GET可以提交更多的数据。难道真的是这样的么?

    而实际上,URL不存在参数上限的问题,HTTP协议规范没有对URL长度进行限制。
    这个限制是特定的浏览器及服务器对它的限制。IE对URL长度的限制是2083字节(2K+35)。对于其他浏览器,如Netscape、FireFox等,理论上没有长度限制,其限制取决于操作系统的支持。
    同时,POST是没有大小限制的,HTTP协议规范也没有进行大小限制。
    POST数据是没有限制的,起限制作用的是服务器的处理程序的处理能力。

    总归一句话,这个限制是针对所有HTTP请求的,与GET、POST没有多少关系。

  • 误区二:POST比GET安全?
    首先,我们要承认安全的概念有很多种,要是从最基本的肉眼看到就不安全,肉眼看不到那就是安全的概念说呢,GET确实没有POST安全,毕竟小白用户确实可以看到在URL中带有的数据信息,这个你无法狡辩。那么要是往严谨了说呢,POST是不是要比GET安全呢?其实不是的。

    上面也说了,GET将提交到服务器的数据添加到URL中了,可见;虽然POST的数据,你肉眼看不到,你抓个包看看,在HTTP包的包体中,我们提交的数据时仍然可见的;所以说,从这方面来说,POST也是以五十步笑百步了。