当前位置: 首页 > article >正文

Chrome 90+ 跨域请求突然失败?手把手教你排查 strict-origin-when-cross-origin 这个‘新’策略

Chrome 90 跨域请求突然失败从原理到实战的完整解决方案最近不少开发者反馈Chrome浏览器升级到90版本后原本正常运行的前端项目突然出现跨域请求失败的问题。控制台只显示一个模糊的strict-origin-when-cross-origin错误让人摸不着头脑。本文将带你深入理解这个新策略的本质并提供一套完整的排查和解决方案。1. 理解strict-origin-when-cross-origin的本质strict-origin-when-cross-origin并非全新的概念而是Chrome团队对默认Referrer Policy的一次重要调整。要真正解决问题我们需要先理解几个关键点Referrer Policy的核心作用是控制浏览器在发送请求时如何携带Referrer信息。这个策略直接影响跨域请求的安全性和隐私保护。Chrome 90版本将默认策略从no-referrer-when-downgrade改为strict-origin-when-cross-origin这一变化带来了三个主要行为同源请求发送完整的URL作为Referrer跨源但安全级别相同(HTTPS→HTTPS)只发送源(协议域名端口)安全级别降级(HTTPS→HTTP)不发送任何Referrer信息注意这个变更主要影响的是Referrer信息的发送方式而非直接导致跨域请求失败。真正的问题往往出现在后端服务对Referrer信息的处理逻辑上。2. 问题诊断从现象到根源的排查流程当遇到跨域请求失败时建议按照以下步骤进行系统排查2.1 检查浏览器开发者工具在Chrome开发者工具的Network面板中重点关注以下几个关键信息请求的Referrer Policy值请求头和响应头的完整内容实际的HTTP状态码不要只看表面显示的200一个典型的异常情况是请求显示200状态码但响应体为空且控制台显示跨域错误。2.2 对比不同环境的表现为了确定问题是浏览器策略变更引起的还是后端配置问题需要进行环境对比测试本地开发环境使用相同Chrome版本访问本地服务生产环境使用相同浏览器访问线上服务不同浏览器使用Firefox或Safari进行对比测试如果问题仅在Chrome 90版本出现基本可以确定是Referrer Policy变更引起的问题。2.3 分析请求流程完整的请求流程可能涉及多个环节需要逐一排查浏览器发送请求时的Referrer信息前端代码中的特殊配置反向代理(Nginx等)的转发规则后端服务的CORS配置安全组或中间件的拦截规则3. 后端解决方案Spring Boot的完整配置对于使用Spring Boot的后端服务需要确保CORS配置正确处理新的Referrer Policy。以下是推荐的完整配置方案Configuration public class WebConfig implements WebMvcConfigurer { Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping(/**) .allowedOrigins(*) .allowedMethods(GET, POST, PUT, DELETE, OPTIONS) .allowedHeaders(*) .exposedHeaders(Authorization) .allowCredentials(true) .maxAge(3600); } }关键配置说明allowedOrigins(*)允许所有源访问生产环境应替换为具体的前端域名allowCredentials(true)允许携带凭证(cookie等)exposedHeaders(Authorization)暴露自定义头部给前端maxAge(3600)预检请求缓存时间提示如果使用了Spring Security还需要在安全配置中明确允许OPTIONS方法的预检请求通过。4. Nginx层的关键配置很多时候请求甚至没有到达后端服务就被Nginx拦截了。以下是必须的Nginx配置location /api/ { proxy_pass http://backend-service; # CORS headers add_header Access-Control-Allow-Origin $http_origin; add_header Access-Control-Allow-Credentials true; add_header Access-Control-Allow-Methods GET, POST, PUT, DELETE, OPTIONS; add_header Access-Control-Allow-Headers DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range,Authorization; # 处理预检请求 if ($request_method OPTIONS) { add_header Access-Control-Max-Age 1728000; add_header Content-Type text/plain; charsetutf-8; add_header Content-Length 0; return 204; } }特别需要注意以下几点Access-Control-Allow-Origin最好使用$http_origin动态设置而不是简单的*当使用凭证(cookie等)时Access-Control-Allow-Origin不能为*必须正确处理OPTIONS方法的预检请求5. 前端适配策略虽然问题主要出在后端配置但前端也可以采取一些措施提高兼容性显式设置Referrer Policymeta namereferrer contentno-referrer-when-downgradeFetch API的特殊处理fetch(url, { credentials: include, referrerPolicy: no-referrer-when-downgrade });axios的全局配置axios.defaults.withCredentials true; axios.defaults.headers.common[Referrer-Policy] no-referrer-when-downgrade;在实际项目中我们遇到过一个典型案例一个运行多年的系统在Chrome自动更新后突然出现跨域问题。经过排查发现后端服务的安全中间件会根据Referrer信息进行额外的安全检查而新的Referrer Policy导致必要的信息缺失触发了拦截机制。最终通过调整中间件的检查逻辑解决了问题。

相关文章:

Chrome 90+ 跨域请求突然失败?手把手教你排查 strict-origin-when-cross-origin 这个‘新’策略

Chrome 90 跨域请求突然失败?从原理到实战的完整解决方案 最近不少开发者反馈,Chrome浏览器升级到90版本后,原本正常运行的前端项目突然出现跨域请求失败的问题。控制台只显示一个模糊的strict-origin-when-cross-origin错误,让人…...

RedisDesktopManager Windows版:5步打造高效Redis数据库管理体验

RedisDesktopManager Windows版:5步打造高效Redis数据库管理体验 【免费下载链接】RedisDesktopManager-Windows RedisDesktopManager Windows版本 项目地址: https://gitcode.com/gh_mirrors/re/RedisDesktopManager-Windows RedisDesktopManager Windows版…...

如何快速掌握Switch文件管理神器:NSC_BUILDER完整新手指南

如何快速掌握Switch文件管理神器:NSC_BUILDER完整新手指南 【免费下载链接】NSC_BUILDER Nintendo Switch Cleaner and Builder. A batchfile, python and html script based in hacbuild and Nuts python libraries. Designed initially to erase titlerights encr…...

传递函数极零点分析:从RC滤波器到系统稳定性设计

1. 从电路到方程:理解传递函数的基石在电子工程,尤其是模拟电路和信号处理领域,我们常常需要精确描述一个系统如何“加工”输入信号。比如,一个简单的RC低通滤波器,它如何让低频信号顺利通过,同时抑制高频噪…...

Kettle 9.3 下载安装全攻略:从官网变动的坑到Hadoop Shims的正确配置

Kettle 9.3 下载安装全攻略:从官网变动的坑到Hadoop Shims的正确配置 如果你最近尝试下载Kettle 9.3,可能会发现一个令人困惑的现象:按照老教程访问SourceForge上的Pentaho项目页面,却找不到熟悉的下载按钮。这不是你的问题&#…...

Spring Validation嵌套校验踩坑实录:用@Valid搞定订单里商品列表的深度验证

Spring Validation嵌套校验实战:用Valid解决订单商品列表的深度验证难题 电商系统中订单创建接口的复杂性往往体现在数据结构的嵌套层级上。一个典型的订单对象不仅包含基础订单信息,还会内嵌商品列表、优惠券、收货地址等多个子对象。当后端接收到这样的…...

网盘直链下载助手:一键获取9大网盘真实下载地址,告别限速烦恼

网盘直链下载助手:一键获取9大网盘真实下载地址,告别限速烦恼 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中…...

3步实现B站缓存视频智能转换:高效保存珍贵学习资源

3步实现B站缓存视频智能转换:高效保存珍贵学习资源 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾为B站缓存视频无法在其他…...

从51到Linux:一个嵌入式工程师的五年踩坑与填坑全记录(附避坑清单)

从51到Linux:一个嵌入式工程师的五年踩坑与填坑全记录(附避坑清单) 五年前,当我第一次点亮51单片机的LED灯时,绝没想到这条路上会有这么多隐藏的陷阱。从寄存器配置的字节对齐问题,到Linux驱动中的竞态条件…...

SpringBoot3 + JDK17 项目实战:用MyBatis-Plus和Redis快速搭建一个用户管理系统

SpringBoot3 JDK17 实战:构建高性能用户管理系统 最近在重构公司内部的管理系统时,我选择了SpringBoot3和JDK17这套组合。新版本带来的性能提升和语法糖让开发效率提高了不少,特别是记录日志和编写Lambda表达式时。本文将带你从零开始&#…...

标签系统的底层同步拓扑:大批量客户标签异步更新的一致性方案

标签(Tag)是私域精细化运营的灵魂。在进行大规模广告投放、或者老客清洗时,企业系统经常需要同时为上万个外部客户批量追加或清空标签。 1. 标签同步的复杂性在哪里? 原生设计中,企业微信的标签是以“企业标签组&#…...

从CTF靶场到实战:手把手教你复现ctfshow web3的PHP伪协议利用(附BurpSuite抓包技巧)

从CTF靶场到实战:深入解析PHP伪协议利用与BurpSuite实战技巧 在网络安全领域,CTF比赛不仅是检验技能的竞技场,更是学习实战渗透技术的绝佳资源。ctfshow web3这道题目巧妙地将PHP伪协议利用与文件包含漏洞结合在一起,为我们提供了…...

Milk-V Duo开发板深度评测:双核RISC-V Linux系统实战与性能优化

1. 开箱初印象:当“小钢炮”遇上“大算力”刚拿到Milk-V Duo开发板时,我承认我愣了一下。包装盒比常见的信用卡还要小一圈,第一反应是“这怕不是个配件或者核心模块吧?”直到拆开静电袋,这块精致得如同艺术品的开发板本…...

如何在Vue3项目中3步完成专业代码编辑器集成:终极指南

如何在Vue3项目中3步完成专业代码编辑器集成:终极指南 【免费下载链接】vue-codemirror codemirror code editor component for vuejs 项目地址: https://gitcode.com/gh_mirrors/vu/vue-codemirror 还在为Vue3项目寻找完美的代码编辑器组件吗?vu…...

【备考高项】模拟预测题(五)案例分析及答案详解

更多内容请见: 《备考信息系统项目管理师》 - 专栏介绍和目录 文章目录 试题一: 【问题1】(10分) 【问题2】(5分) 【问题3】(6分) 【问题4】(4分) 试题二 【问题1】(4分) 【问题2】(3分) 【问题3】(8分) 【问题4】(7分) 【问题5】(8分) 试题三 【问题1】(…...

GNSS数据处理避坑指南:为什么你的PPP精度总上不去?可能是SP3和CLK文件用错了

GNSS数据处理避坑指南:为什么你的PPP精度总上不去?可能是SP3和CLK文件用错了 当你花费数小时运行PPP解算,却发现定位结果始终达不到预期精度时,那种挫败感我深有体会。作为从事高精度GNSS数据处理多年的工程师,我见过太…...

从OpenMV2到4代,我踩过的那些坑:画面变绿、传感器接触不良与内存擦除的避坑实录

从OpenMV2到4代:硬件升级中的稳定性挑战与实战解决方案 作为一名长期使用OpenMV系列开发视觉项目的工程师,我从OpenMV2一路升级到4代,见证了硬件性能的飞跃,也深刻体会到稳定性问题带来的困扰。其中最令人头疼的莫过于"画面变…...

uniapp监听PDA扫码,除了广播还能怎么玩?聊聊H5+扩展与原生插件的选择

Uniapp中PDA扫码方案深度对比:从广播监听走向原生封装 在工业级移动应用开发中,PDA(便携式数据采集器)的扫码功能集成一直是刚需场景。霍尼韦尔EDA50P等专业设备虽然提供了默认的广播机制,但随着业务复杂度提升&#x…...

别再乱设Public了!Minio权限控制实战:从用户、分组到自定义策略的完整配置流程

别再乱设Public了!Minio权限控制实战:从用户、分组到自定义策略的完整配置流程 在分布式存储系统的日常运维中,权限配置不当引发的数据泄露事件屡见不鲜。最近某科技公司因对象存储桶误设为公开访问,导致数万份客户资料暴露的案例…...

别再只用K-Means了!用DBSCAN搞定非球形数据聚类(附Python代码实战)

突破K-Means局限:DBSCAN在复杂数据聚类中的实战指南 当数据科学家面对那些"不听话"的非球形分布数据集时,传统K-Means算法往往会束手无策。想象一下这样的场景:你的客户分群数据呈现出笑脸形状的分布,或者市场调研数据形…...

Python实战:基于InsightFace构建实时人脸识别系统

1. 环境准备与InsightFace初探 第一次接触人脸识别系统开发时,我被各种算法和框架搞得晕头转向,直到发现了InsightFace这个宝藏库。它就像瑞士军刀一样集成了人脸检测、对齐、识别全套功能,而且对Python开发者特别友好。记得当时用OpenCVDlib…...

【人工智能】某公司AI落地实践总结

某公司AI落地实践总结 一、AI落地的整体路径框架 某公司的AI落地遵循"认知 → 工具使用 → 流程自动化 → 高阶能力构建 → 场景化落地 → 持续迭代 → 激励驱动"的闭环路径,具体分为四个阶段: 初阶入门(认知筑基):AI基础概念与常用工具,零基础扫盲,掌握提示…...

Perplexity到底值不值得替代搜索引擎?37小时实测+127次对比查询,答案出人意料

更多请点击: https://intelliparadigm.com 第一章:Perplexity到底值不值得替代搜索引擎?37小时实测127次对比查询,答案出人意料 实测设计与数据采集方法 我们构建了覆盖技术文档、学术论文、实时新闻、API调试、开源项目溯源五大…...

【Autosar】MCAL - 从零到一的工程配置实战

1. 工程创建:从零搭建MCAL开发环境 第一次打开Autosar配置工具时,面对满屏的选项确实容易发懵。记得我刚接触MCAL配置时,光是工程创建就反复折腾了好几次。下面我就把踩过的坑和验证过的正确姿势分享给大家。 创建新工程时,工程名…...

别再死记硬背了!用这 5 个核心功能理解 Final Cut Pro 的设计哲学

Final Cut Pro 的设计哲学:5个核心功能如何重塑你的剪辑思维 当你第一次打开Final Cut Pro(简称FCPX),可能会被它与其他剪辑软件截然不同的界面所困惑。这不是一个需要你适应传统时间线的工具,而是一个重新思考剪辑流程…...

告别标注烦恼!用DINO+ViT自监督训练,5步搞定你的图像特征提取器(附代码)

5步实战DINOViT自监督训练:零标注构建高效图像特征提取器 在计算机视觉领域,数据标注一直是制约模型性能提升的瓶颈。传统监督学习需要大量人工标注数据,而高质量标注不仅成本高昂,还可能引入人为偏见。自监督学习(self-supervise…...

手把手教你搭建低成本雷达测试环境:从暗室搭建到模拟器参数设置(基于国产设备实战)

低成本雷达测试环境搭建实战:国产设备方案与操作指南 在车载毫米波雷达研发领域,测试环节往往占据着项目预算的显著部分。传统方案依赖进口设备和专业暗室,动辄数百万元的投入让许多中小型团队望而却步。本文将揭示一个行业内的真实情况&…...

高效精准的SacreBLEU实战指南:机器翻译评估的专业解决方案

高效精准的SacreBLEU实战指南:机器翻译评估的专业解决方案 【免费下载链接】sacrebleu Reference BLEU implementation that auto-downloads test sets and reports a version string to facilitate cross-lab comparisons 项目地址: https://gitcode.com/gh_mirr…...

为ubuntu上的自动化脚本寻找稳定大模型api源taotoken的接入方案

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 为 Ubuntu 上的自动化脚本寻找稳定大模型 API 源:Taotoken 的接入方案 在 Ubuntu 环境中运行自动化脚本或智能体时&…...

别再用时间机器了!用macOS恢复模式重装系统,保姆级图文教程(含抹盘避坑指南)

别再用时间机器了!用macOS恢复模式重装系统,保姆级图文教程(含抹盘避坑指南) 当你发现Mac运行速度明显变慢,或者准备转手出售设备时,彻底重装系统往往是最有效的解决方案。许多用户对macOS恢复模式存在本能…...