【知识归纳】浏览器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问答

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

相关推荐
前端 贾公子32 分钟前
release-it 使用指南
前端·javascript
摘星编程2 小时前
React Native + OpenHarmony:Modal确认取消弹窗
javascript·react native·react.js
xkxnq2 小时前
第四阶段:Vue 进阶与生态整合(第 47 天)(Vue 项目目录结构解析:每个文件夹的作用与规范)
前端·javascript·vue.js
意法半导体STM323 小时前
【官方原创】如何基于DevelopPackage开启安全启动(MP15x) LAT6036
javascript·stm32·单片机·嵌入式硬件·mcu·安全·stm32开发
奔跑的web.4 小时前
TypeScript namespace 详解:语法用法与使用建议
开发语言·前端·javascript·vue.js·typescript
你怎么知道我是队长4 小时前
win11系统查看设备配置
android·java·javascript
雨季6664 小时前
构建 OpenHarmony 简易 BMI 健康指数计算器:用基础数学实现健康自评
javascript·flutter·ui·自动化·dart
晚霞的不甘4 小时前
Flutter for OpenHarmony:从零到一:构建购物APP的骨架与精美UI
前端·javascript·flutter·ui·前端框架·鸿蒙
ElasticPDF-新国产PDF编辑器5 小时前
基于 PDF.js 的 PDF 文字编辑解决方案,纯前端 SDK,跨平台、框架无关、Web 原生
前端·javascript·pdf