
本文旨在解决在使用 JavaScript 的 fetch API 发送请求时,如何正确设置 Referer 请求头,模拟 PHP 中 CURLOPT_REFERER 的功能。我们将通过示例代码和注意事项,详细讲解如何在 fetch 请求中添加 Referer,并避免常见的错误。
在 JavaScript 的 fetch API 中,要设置 Referer 请求头,不能直接使用 referrer 选项。referrer 选项主要用于控制浏览器在导航到新页面时如何设置 Referer 头,而不是用于控制 fetch 请求的 Referer 头。
正确的做法是将 Referer 头添加到 fetch 请求的 headers 对象中。以下是一个示例:
const cookie = "cookie";
const csrf = "assuming we have csrf ticket already";
async function getAuthenticationTicket() {
try {
const response = await fetch(
"https://auth.roblox.com/v1/authentication-ticket",
{
method: "POST",
headers: {
Cookie: ".ROBLOSECURITY=" + cookie,
"x-csrf-token": csrf,
"Referer": "https://www.roblox.com/home" // 正确设置 Referer 的方式
},
}
);
if (!response.ok) {
console.error(`HTTP error! status: ${response.status}`);
const errorText = await response.text();
console.error(`Error Response: ${errorText}`);
return;
}
const ticket = await response.text();
console.log(ticket);
} catch (error) {
console.error("Fetch error:", error);
}
}
getAuthenticationTicket();代码解释:
立即学习“Java免费学习笔记(深入)”;
注意事项:
总结:
通过将 "Referer" 键添加到 fetch 请求的 headers 对象中,我们可以正确地设置 Referer 请求头。在实际应用中,请注意安全性、CORS 策略和错误处理,以确保请求能够成功发送并获得预期的结果。避免使用 referrer 选项来设置请求头,因为它主要用于控制导航行为,而不是 fetch 请求。
以上就是JavaScript Fetch 请求中设置 Referer 的正确方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号