Get和Post的区别

区别:

  1. GET在浏览器回退时是无害的,而POST会再次提交请求。
  2. GET产生的URL地址可以被Bookmark,而POST不可以。
  3. GET请求会被浏览器主动cache,而POST不会,除非手动设置。
  4. GET请求只能进行url编码,而POST支持多种编码方式。
  5. GET请求参数会被完整保留在浏览器历史记录里,而POST中的参数不会被保留。
  6. GET请求在URL中传送的参数是有长度限制的,而POST么有。
  7. 对参数的数据类型,GET只接受ASCII字符,而POST没有限制。
  8. GET比POST更不安全,因为参数直接暴露在URL上,所以不能用来传递敏感信息。
  9. GET参数通过URL传递,POST放在Request body中。

实际原理:

https://www.cnblogs.com/logsharing/p/8448446.html

GET和POST还有一个重大区别,简单的说:

GET产生一个TCP数据包;POST产生两个TCP数据包。

 

长的说:

对于GET方式的请求,浏览器会把http header和data一并发送出去,服务器响应200(返回数据);

而对于POST,浏览器先发送header,服务器响应100 continue,浏览器再发送data,服务器响应200 ok(返回数据)。

 

### HTTP GETPOST方法的区别详解 GETPOST是HTTP协议中最常用的两种请求方法,它们在功能、用途以及实现方式上存在显著差异。以下是GETPOST请求之间的主要区别: #### 1. 请求参数的传递方式 - **GET请求**:参数通过URL传递,直接显示在浏览器地址栏中。这种方式适合传输少量且非敏感的数据[^1]。 - **POST请求**:参数放在请求体(Request Body)中,不会直接显示在浏览器地址栏中。这种方式适合传输大量或敏感数据[^4]。 #### 2. 安全性 - **GET请求**:由于参数直接暴露在URL中,且会完整保留在浏览器历史记录中,因此不适合传输敏感信息[^5]。 - **POST请求**:虽然参数不直接暴露在URL中,但HTTP本身是明文传输,通过抓包工具仍可轻易获取请求体中的数据。因此,为了保证安全性,应使用HTTPS协议对数据进行加密[^2]。 #### 3. 缓存机制 - **GET请求**:会被浏览器主动缓存,除非手动设置禁用缓存。 - **POST请求**:通常不会浏览器缓存,需要额外配置才能实现缓存。 #### 4. 数据编码方式 - **GET请求**:仅支持URL编码,所有非ASCII字符都必须在请求前进行转码。 - **POST请求**:支持多种编码方式,如application/x-www-form-urlencoded、multipart/form-data等,可以通过MIME类型传输非ASCII字符[^4]。 #### 5. 数据量限制 - **GET请求**:受URL长度限制,不同浏览器服务器对URL长度的支持有所不同,通常建议不超过2048个字符。 - **POST请求**:理论上没有长度限制,具体取决于服务器配置。 #### 6. 功能用途 - **GET请求**:主要用于获取资源,具有安全、幂等、可缓存的特点[^3]。 - **POST请求**:主要用于提交数据或更新资源,不具备幂等性,不可缓存。 #### 7. 历史记录 - **GET请求**:参数会完整保留在浏览器历史记录中[^4]。 - **POST请求**:参数不会保留在浏览器历史记录中。 #### 示例代码 以下是一个简单的GETPOST请求示例,分别使用Python的`requests`库实现: ```python import requests # GET请求示例 response_get = requests.get("https://example.com/api/data", params={"key": "value"}) print(response_get.url) # 输出完整的URL,包含参数 # POST请求示例 response_post = requests.post("https://example.com/api/data", data={"key": "value"}) print(response_post.status_code) # 输出响应状态码 ``` ### 总结 GETPOST请求在HTTP协议中有明确的分工。GET主要用于数据的获取,适合传输少量、非敏感数据;而POST主要用于数据的提交修改,适合传输大量或敏感数据。在实际开发中,正确选择请求方法不仅关系到应用的功能性,还涉及到安全性效率问题。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值