本文旨在解决在使用 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号