使用 JavaScript 的 XMLHttpRequest
或 Fetch API 发送 HTTP 请求时,GET
请求和 POST
请求处理参数的方式不同,这与 HTTP 协议的设计有关
GET 请求的参数
- 特点:GET 请求的参数通过 URL 传递。
- 原因:
- URL 表现方式:GET 请求的主要目的是从服务器获取资源。URL 是资源的唯一标识,因此 GET 请求的所有参数都附加在 URL 上,作为请求资源的一部分。
- HTTP 协议的约定:GET 请求的请求体(
body
)不用于传递数据。按照规范,GET 请求的主体通常被忽略,即使你在send()
方法中传递参数,服务器也不会处理。 - 浏览器兼容性和缓存机制:浏览器和代理服务器会根据 URL 缓存 GET 请求。通过 URL 传递参数可以方便缓存的使用。
设置 GET 请求参数
在 XMLHttpRequest
中:
let xhr = new XMLHttpRequest(); xhr.open("GET", "https://example.com/api?param1=value1¶m2=value2", true); xhr.send(); // send() 不包含任何数据
- 参数被直接拼接到 URL 后的查询字符串(
?key=value&key2=value2
)。 send()
方法传递的数据在 GET 请求中无效,按照规范,GET 请求不会处理请求体。
POST 请求的参数
- 特点:POST 请求的参数通过 请求体(body)传递。
- 原因:
- 请求目的不同:POST 请求的主要目的是将数据发送到服务器,比如表单提交、数据上传等。参数通过请求体发送,更适合传递大量数据或复杂数据。
- 协议支持:HTTP 规范允许 POST 请求通过请求体发送数据,并且通常由服务器接收和解析。
- 安全性和长度限制:相比于 GET 请求,POST 请求更适合传递敏感数据,因为参数不直接暴露在 URL 中。此外,URL 的长度通常受到限制,而请求体的长度限制较大。
在 XMLHttpRequest
中:
let xhr = new XMLHttpRequest(); xhr.open("POST", "https://example.com/api", true); xhr.setRequestHeader("Content-Type", "application/json"); xhr.send(JSON.stringify({ param1: "value1", param2: "value2" })); // 参数在请求体中传递
对比总结
为什么 send() 在 GET 请求中不发送数据?
- HTTP 协议中规定 GET 请求不需要请求体,
send()
方法传递的数据在 GET 请求中会被忽略。 - 参数已经通过
open()
方法中的 URL 指定,无需再用send()
传递。
因此,send()
在 GET 请求中只用于触发请求,不携带数据是符合 HTTP 设计的行为。