两种HTTP请求方法:GET和POST的区别

之前在一些开发者平台使用网页调用API时,一再提到两种请求方法GET和POST,所以就去了解了下。那么这又不得不提到HTTP了!

一、什么是 HTTP?

超文本传输协议(HTTP)的设计目的是保证客户机与服务器之间的通信。HTTP 的工作方式是客户机与服务器之间的请求-应答协议。web 浏览器可能是客户端,而计算机上的网络应用程序也可能作为服务器端。

 

二、两种 HTTP 请求方法:GET 和 POST

在客户机和服务器之间进行请求-响应时,两种最常被用到的方法是:GET 和 POST。

1、GET 方法:从指定的资源请求数据。

 

请注意,查询字符串(名称/值对)是在 GET 请求的 URL 中发送的:

例如:https://www.xxxx.com/xxx.asp? name1=value1&name2=value2  

 

而需要注意的是:GET方法是可见的,而POST方法是在HTTP消息主体中发出的,具有不可见性。下面是一些GET的注释

1.1.GET 请求可被缓存。

1.2.GET 请求保留在浏览器历史记录中。

1.3.GET 请求可被收藏为书签。

1.4.GET 请求不应在处理敏感数据时使用

1.5.GET 请求有长度限制

1.6.GET 请求只应当用于取回数据

 

2、POST 方法:向指定的资源提交要被处理的数据

  请注意,查询字符串(名称/值对)是在 POST 请求的 HTTP 消息主体中发送的:

GET方法是可见的,而POST方法是在HTTP消息主体中发出的,具有不可见性。下面是一些 POST的注释

 

2.1.POST 请求不会被缓存

2.2.POST 请求不会保留在浏览器历史记录中

2.3.POST 不能被收藏为书签

2.4.POST 请求对数据长度没有要求

 

三、比较 GET 与 POST

下面比较了两种 HTTP 方法:GET 和 POST。

1. 后退按钮/刷新:

GET--->无害。  

POST--->数据会被重新提交(浏览器应该告知用户数据会被重新提交)。

2. 书签:

GET--->  可收藏为书签。

   POST--->不可收藏为书签。

3. 缓存:

GET--->能被缓存。

POST--->不能缓存 。

4. 编码类型:

GET--->application/x-www-form-urlencoded 。

POST--->application/x-www-form-urlencoded 或 multipart/form-data。为二进制数据使用多重编码。

5. 历史:

GET--->参数保留在浏览器历史中。

   POST---> 参数不会保存在浏览器历史中。

6. 对数据长度的限制:

GET----> 是的。当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。

   POST--->  无限制。

7. 对数据类型的限制:

GET---->只允许 ASCII 字符。

   POST---> 没有限制。也允许二进制数据。

8. 安全性:

GET----> 与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。在发送密码或其他敏感信息时绝不要使用 GET !

   POST--->  POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。

9. 可见性:

GET--->数据在 URL 中对所有人都是可见的。

POST---> 数据不会显示在 URL 中。

 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

 

猜你喜欢

转载自blog.csdn.net/qq_34490018/article/details/79650794