一 使用原则
GET 用于向服务端获取/查询数据,POST 用于向服务端传递数据(包括增删改)
二 传输方式和安全性(重要)
GET 是通过拼接 URL 传递参数,key 和 value一一对应,这些参数会被浏览器缓存,数据会被暴露在URL中,在 URL 中可以看到其参数和值,容易被篡改和误操作,因此安全性较低;而 POST 是通过 body 体传输参数,数据不会被浏览器缓存,安全性相对较高,不易被攻击者获取,在 URL 中不可见
三 传输数据的大小和速度
GET 传输的文件大小不超过 2KB ,由于大小限制,传输速度会快于 POST ,POST 请求数据大小取决于 php.ini 配置文件或后端设置的大小(可以无限大)
四 缓存性
GET 可以缓存,参数会被完整地保留在浏览器历史记录中,而 POST 不可以,因此 GET 数据有可能会被攻击者通过浏览器获取
五 数据产生
GET 会把请求头和请求体一并发送出去(只发送一次 TCP数据包),对于 POST ,先发送请求头,再发送请求体(发送两次 TCP数据包)
六 后退/刷新产生的结果
GET 请求的页面后退时不产生任何影响,GET请求是一种幂等操作(多次请求结果相同),而 POST 请求的页面后退时会重新提交请求此外,POST请求不是幂等操作(多次请求结果可能不同)
七 书签收藏
GET请求可以收藏,但POST请求不可以
八 数据类型
GET 请求只可以接收 ASCII 字符,POST 请求可以接收二进制类型的数据,对数据类型并没有限制