https://www.cnblogs.com/ambon/articles/4535347.html 什么时候用GET,什么时候用POST 原文:http://bu-choreography.iteye.com/blog/1013501 刚开始学习Web开发的时候,总会遇到提交表单时使用GET方法还是POST方法的问题,最开始的时候因为没有经验并没有领悟,后来框架开发做多了,更是把这些原始基础知识扔出了银河系。最近开到一段W3的资料,写的不错,原文地址如下:http://bu-choreography.iteye.com/admin/blogs/new。翻译总结如下: 快速判断: 如下情况使用GET方法:客户端与服务端的交互像是一个提问(如查询操作、搜索操作、读操作) 如下情况使用POST方法: 1.交互是一个命令或订单(order),比提问包含更多信息 2.交互改变了服务器端的资源并被用户察觉,例如订阅某项服务 3.用户需要对交互产生的结果负责 听起来稍微明白了一点,接着来。 根据HTTP协议规定,GET方法可以携带交互需要的所有数据,因此你会看到搜索百度或谷歌的时候,点击搜索形成的URL包含了你刚才的搜索关键字,没有安全需求的请求把信息放URL里没关系,但是你访问银行网站的时候,不希望把账户、密码这些放在URL里被人拦截是吧,所以HTTP设计了POST请求,他可以把请求信息放在HTTP请求里,具体格式这里不细说了,这样你就不能简单的从URL里找到账户、密码了。 讲完这些,是不是比较清楚了呢。 文章还例举了几个曾经的HTTP请求限制。 1.URI不能超过256个字符。这个限制在有些服务器里是存在的,有的服务器为了网络安全,为了防止拒绝式攻击会把URL字符限制在4000字符 2.你提交了GET请求,又马山按了backspace键,会导致get方法被重新执行 3.你在一个页面使用了安全协议,跳转到了另一个使用不安全协议的页面时,会导致安全数据泄漏给第二个页面。 4搜索服务不检索包含问号的URI 原文:http://blog.csdn.net/perny/article/details/7465243 GET和POST两种方法都是将数据送到服务器,但你该用哪一种呢? HTTP标准包含这两种方法是为了达到不同的目的。POST用于创建资源,资源的内容会被编入HTTP请示的内容中。例如,处理订货表单、在数据库中加入新数据行等。 当请求无副作用时(如进行搜索),便可使用GET方法;当请求有副作用时(如添加数据行),则用POST方法。一个比较实际的问题是:GET方法可能会产生很长的URL,或许会超过某些浏览器与服务器对URL长度的限制。 若符合下列任一情况,则用POST方法: * 请求的结果有持续性的副作用,例如,数据库内添加新的数据行。 * 若使用GET方法,则表单上收集的数据可能让URL过长。 * 要传送的数据不是采用7位的ASCII编码。 若符合下列任一情况,则用GET方法: * 请求是为了查找资源,HTML表单数据仅用来帮助搜索。 * 请求结果无持续性的副作用。 * 收集的数据及HTML表单内的输入字段名称的总长不超过1024个字符。 最早的搜索为了防止无限循环是这么做的,但是限制采用其他办法了,自然也没这个限制了