1、请求的形式
- GET请求:请求的数据会附加在URL之后,以?分割URL和传输数据,多个参数用&连接。URL的编码格式采用的是ASCII编码,而不是uniclde,即是说所有的非ASCII字符都要编码之后再传输。
- POST请求:会把请求的数据放置在HTTP请求包的包体中。
例如下面的name=shuaige就是实际的传输数据。
[plain] view plain copy
POST /inventory-check.cgi HTTP/1.1
Host: www.joes-hardware.com
Content-Type: text/plain
Content-length: 18
item=shuaige 2647
2、传输数据的大小
- GET请求:在HTTP规范中,没有对URL的长度和传输的数据大小进行限制。但是在实际开发过程中,对于GET,特定的浏览器和服务器对URL的长度有限制。因此,在使用GET请求时,传输数据会受到URL长度的限制,一般传送的数据量不超过2KB
- POST请求:由于不是URL传值,理论上是不会受限制的,但是实际上各个服务器会规定对POST提交数据大小进行限制,Apache、IIS都有各自的配置。
3、安全性
- GET请求:传输的参数安全性低,因为传输的数据会显示在URL中,所有人都是可见的,并且会被缓存和保留在浏览器历史中。
- POST请求:数据存放在请求包中进行传输,不会显示在 URL 中,并且参数不会被缓存和保存在浏览器历史或 web 服务器日志中。
4、传输数据的类型
- GET请求:只允许 ASCII 字符
- POST请求:支持多种数据类型
5、对服务器的影响
- GET请求:从服务器上获取数据,也就是所谓的查,仅仅是获取服务器资源,不进行修改。
- POST请求:向服务器提交数据,这就涉及到了数据的更新,也就是更改服务器的数据。