【HTTP】全面比较HTTP GET与POST方法
全面比较HTTP GET与POST方法
1. 基本信息比较
| 属性 | GET方法 | POST方法 | 
| 历史: | 通常使用GET方法发送的数据作为URL的一部分将会被浏览器保存起来 | 使用POST方法提交的数据则不会作为URL的一部分,当然不会浏览器保存。 | 
| 书签: | GET方法可能被浏览器当作书签(bookmark)保存 | POST方法则不会 | 
| 回退与重新提交: | 使用GET方法的页面可以被回退并重新执行而不通知用户 | POST方法会通知用户再次提交 | 
| Form编码类型: | GET提交数据只支持 application/x-www-form-urlencoded | POST支持application/x-www-form-urlencoded与multipart/form-data | 
| 参数: | 由于GET的参数一般都跟在URL后面,支持的数据大小一般在2K,有些服务器可以支持到64K。这个就是很多网页超过64K就挂掉的真实原因。因为服务器限制了。 | 发送参数,还可以是文件,大小在理论上没有限制。 | 
| 被攻击: | GET方法提交数据很容易被黑客攻击,实施脚本绑架。 | POST方法相对GET方法不是那么容易被黑客攻击 | 
| 数据类型限制: | GET方法提交数据只能是文本数据 | POST方法则不受限制,二进制文件也可以。 | 
| 安全性: | GET方法的安全性比POST方法要低一些,原因是数据做为URL的一部分是可见的。而且被浏览器存在历史访问记录中。 | POST方法的安全性相对GET要高一些。因为参数数据不能被浏览器作为URL的一部分而存入历史访问记录中。 | 
| 表单数据长度: | 由于表单数据做为URL的一部分而URL长度通常是有限制的。 | POST方法没有限制。 | 
| 可用性: | GET方法通常不被用来发送密码与敏感信息。但是我发现还是有不少网站用GET来实现login。比如XXXX社区,它把login方法放在一个jquery完成JavaScript脚本中,用GET请求完成。 | POST方法可以用来发送密码与其他敏感信息。 | 
| 可见性: | GET方法对所有人可见 | POST方法的变量是不可见的在URL中 | 
| 缓存: | GET方法默认被缓存,这个就是很多时候用GET方法获取数据后面要跟个时间戳的原因 | POST方法默认不被缓存。 除非Response头设置了Cache-Control或者Expires属性值。 | 
| 最大的变量值: | GET支持最大为7607个字符 | POST方法支持最大值为8MB | 
| 应用场合: | GET最常用的场合是获取数据,浏览器获取网页时候绝大多数通过GET方法实现,大多数浏览器下载也是使用GET方法获取文件 | POST主要用来向服务器提交数据。 | 
个人整理与总结,欢迎大家拍砖
http://blog.csdn.net/jia20003/article/details/8497108
【HTTP】全面比较HTTP GET与POST方法的更多相关文章
- javaSE27天复习总结
		JAVA学习总结 2 第一天 2 1:计算机概述(了解) 2 (1)计算机 2 (2)计算机硬件 2 (3)计算机软件 2 (4)软件开发(理解) 2 (5) ... 
- mapreduce多文件输出的两方法
		mapreduce多文件输出的两方法 package duogemap; import java.io.IOException; import org.apache.hadoop.conf ... 
- 【.net 深呼吸】细说CodeDom(6):方法参数
		本文老周就给大伙伴们介绍一下方法参数代码的生成. 在开始之前,先补充一下上一篇烂文的内容.在上一篇文章中,老周检讨了 MemberAttributes 枚举的用法,老周此前误以为该枚举不能进行按位操作 ... 
- IE6、7下html标签间存在空白符,导致渲染后占用多余空白位置的原因及解决方法
		直接上图:原因:该div包含的内容是靠后台进行print操作,输出的.如果没有输出任何内容,浏览器会默认给该空白区域添加空白符.在IE6.7下,浏览器解析渲染时,会认为空白符也是占位置的,默认其具有字 ... 
- 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例
		前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ... 
- [C#] C# 基础回顾 - 匿名方法
		C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ... 
- ArcGIS 10.0紧凑型切片读写方法
		首先介绍一下ArcGIS10.0的缓存机制: 切片方案 切片方案包括缓存的比例级别.切片尺寸和切片原点.这些属性定义缓存边界的存在位置,在某些客户端中叠加缓存时匹配这些属性十分重要.图像格式和抗锯齿等 ... 
- [BOT] 一种android中实现“圆角矩形”的方法
		内容简介 文章介绍ImageView(方法也可以应用到其它View)圆角矩形(包括圆形)的一种实现方式,四个角可以分别指定为圆角.思路是利用"Xfermode + Path"来进行 ... 
- JS 判断数据类型的三种方法
		说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ... 
- .NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法
		.NET Core中间件的注册和管道的构建(3) ---- 使用Map/MapWhen扩展方法 0x00 为什么需要Map(MapWhen)扩展 如果业务逻辑比较简单的话,一条主管道就够了,确实用不到 ... 
随机推荐
- OpenStack_Swift源代码分析——创建Ring及加入�设备源代码算法具体分析
			1 创建Ring 代码具体分析 在OpenStack_Swift--Ring组织架构中我们具体分析了Ring的具体工作过程,以下就Ring中添加�设备,删除设备,已经又一次平衡的实现过程作具体的介绍. ... 
- LabVIEW设计模式系列——资源关闭后错误处理
			标准: 1.很多引用资源其打开函数和关闭函数对错误处理的方式有所不同:2.一般地NI的Help里对打开函数的错误端子的解释是这样的:如错误发生在VI或函数运行之前,VI或函数将把错误输入值传递至错误输 ... 
- xmemcached user guide --存档
			XMemcached Introduction XMemcached is a new java memcached client. Maybe you don't know "memcac ... 
- Linux下git的配置
			需求和环境 硬件:一台装有Ubuntu14.04的PC 软件:git-core.openssh-server.openssh-client Git的安装 sudo apt-get install gi ... 
- Spring整合CXF步骤,Spring实现webService,spring整合WebService
			Spring整合CXF步骤 Spring实现webService, spring整合WebService >>>>>>>>>>>> ... 
- 关于jquery获取服务器端xml数据
			其实这个很简单,但是有时候简单的东西会让你犯一些低级错误. 今天写了个spring mvc 的服务器端接口,主要是用来共享一些数据库数据. 请求字段:http://localhost:8080/XXX ... 
- 常见sql语句及复杂sql语句记录
			1 将A表中的部分字段和B表中的部分字段作为C表的字段 SELECT a.name,b.age FROM (SELECT * from A) as a,(SELECT * from B) as ... 
- ASP.NET程序如何更新发布
			ASP.NET程序如何更新发布 一.首先右键项目,点击“发布” 然后,新建名称.类型选择文件,然后点击下一步: 点击发布即可! 二. 
- oracle学习笔记2:创建修改表
			1.创建表 CREATE TABLE ORDERINFO ( ORDERID NUMBER(*, 0) NOT NULL , ORDERCODE VARCHAR2(20 BYTE) NOT NULL ... 
- Centos6.5 install Python2.7 & django & mysql & apache
			#! /bin/bash#su root#get python2.7wget https://www.python.org/ftp/python/2.7.9/Python-2.7.9.tgz #ins ... 
