【知识归纳】浏览器Referer策略

浏览器在发起网络请求时携带的Referer头部用于标识请求发起的源页面地址。它主要有以下用途:

  • 来源追踪:服务器可以通过Referer头部了解用户从哪个页面链接跳转过来的,这对于分析网站流量来源很有帮助。
  • 防盗链:网站可以检查Referer头部来确定请求是否由授权的来源发起,以防止其他网站盗用资源。
  • 缓存优化:代理服务器或CDN可能会根据Referer头部决定是否提供缓存内容。
  • 个性化内容:网站可能根据Referer提供定制化内容或推荐。

但是,也存在隐私问题,因为Referer可能会泄露用户浏览信息。因此,有时会通过HTTP头部的Referrer-Policy来控制Referer头部的发送策略。

Referrer-Policy 可以由前端或服务端设置。

前端设置

在HTML中,可以通过<meta>标签来指定:

html 复制代码
<meta name="referrer" content="no-referrer">

关于meta标签中namereferrer时,content可以是以下几个值:

  • no-referrer:不发送referer头部。
  • origin:发送referer头部,但只包含主域部分。
  • no-referrer-when-downgrade:默认值,对于跨协议请求(例如从HTTPS网页到HTTP网页),不发送referer头部;对于同协议请求,发送referer头部,但只包含主域部分。
  • origin-when-cross-origin:对于跨域请求,发送referer头部,但只包含主域部分;对于同域请求,发送完整URL路径作为referer
  • unsafe-url:发送完整URL路径作为referer,包括路径和查询参数。

当你将meta标签的content设置为unsafe-url时,它会将referer设置为完整的URL路径,包括路径和查询参数。这可能会带来以下安全风险:

  • 隐私泄露:完整的URL路径可能包含敏感信息,例如会话标识、个人身份信息等。将完整URL路径作为referer可能会泄露这些敏感信息给第三方网站。
  • 信息泄露:通过referer头部,网站所有者可以获得访问来源的信息,包括从哪个网页跳转过来。使用完整URL路径作为referer可能会泄露用户访问来源的信息。
  • 跨站请求伪造(CSRF):完整URL作为referer可能会增加跨站请求伪造攻击的风险,攻击者可以利用referer来伪装请求来源,从而进行恶意操作。

请注意,虽然在某些情况下使用unsafe-url可以满足你的需求,但它可能会增加安全风险。在使用时,请确保评估并采取适当的安全措施来保护用户隐私和防止潜在的攻击。

服务端设置

在HTTP响应头中设置Referrer-Policy

js 复制代码
Referrer-Policy: no-referrer

当服务端在响应中设置Referrer-Policy时,它会影响浏览器在处理当前页面的后续请求时Referer头部的发送行为。也就是说,服务端设置的Referrer-Policy会影响当前页面加载后续资源或发起的其他请求的Referer传递策略。

在实际应用中,通常希望服务端预先设置好Referrer-Policy,这样浏览器在接收到第一次响应后,就能够按照这个策略处理所有后续请求。如果服务端在后续的响应中改变或重新设置Referrer-Policy,那么浏览器将按照最新的策略处理接下来的请求。

参考文档

  • GPT问答

本文已收录至博客《前端从入门到入土》,欢迎点赞、收藏 + 关注~

相关推荐
炫饭第一名3 分钟前
速通Canvas指北🦮——路径与形状篇
前端·javascript·程序员
无责任此方_修行中24 分钟前
如何利用 pnpm 的安全控制功能防御 npm 供应链攻击
javascript·npm·node.js
进击的尘埃1 小时前
前端状态管理的本质:从 Vuex 到 Pinia,我们到底在管理什么?
javascript
码路飞1 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
Lee川1 小时前
从回调地狱到同步之美:JavaScript异步编程的演进之路
javascript·面试
进击的尘埃1 小时前
WebSocket 长连接方案设计:从心跳保活到断线重连的生产级实践
javascript
摸鱼的春哥3 小时前
Agent教程15:认识LangChain(中),状态机思维
前端·javascript·后端
明月_清风3 小时前
告别遮挡:用 scroll-padding 实现优雅的锚点跳转
前端·javascript
明月_清风3 小时前
原生 JS 侧边栏缩放:从 DOM 监听到底层优化
前端·javascript
炫饭第一名17 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员