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

微服务下的跨域问题

在单体架构时代跨域问题还不算突出但进入微服务、前后端分离、多端统一时代跨域几乎是每个项目必踩的坑。尤其在微服务架构下网关、认证、分布式部署、多域名并存让跨域变得更复杂、更隐蔽。本文从浏览器同源策略讲起结合微服务真实场景把跨域原理、常见方案、网关统一处理、避坑要点一次性讲透适合直接发布 CSDN 学习与收藏。一、什么是跨域为什么会出现跨域1.1 同源策略Same-Origin Policy跨域限制本质是浏览器的安全机制服务器本身不存在跨域限制。同源 协议 域名 端口 三者完全一致只要有一个不一样浏览器就判定为 “跨域”会拦截响应前端拿不到数据。举例以http://a.com:8080为基准表格请求地址是否跨域原因http://a.com:8080/api否完全同源https://a.com:8080/api是协议不同http/httpshttp://api.a.com:8080是域名不同http://a.com:9090/api是端口不同1.2 为什么微服务更容易跨域微服务天生就是多应用、多域名、多端口、多实例部署前端http://localhost:8080网关http://gateway:8888用户服务http://user:8001订单服务http://order:8002只要前端直接 / 间接访问非同源地址就会触发跨域。典型报错plaintextAccess to XMLHttpRequest at xxx from origin xxx has been blocked by CORS policy: No Access-Control-Allow-Origin header is present on the requested resource.二、跨域核心知识点简单请求 预检请求2.1 简单请求满足以下全部条件为简单请求方法GET / HEAD / POST请求头只包含Accept、Accept-Language、Content-Type等Content-Type 仅限application/x-www-form-urlencodedmultipart/form-datatext/plain特点只发一次请求直接携带跨域头。2.2 预检请求OPTIONS不满足简单请求就会触发预检自定义请求头如tokenContent-Type: application/json使用PUT / DELETE / PATCH浏览器会先发一次OPTIONS请求询问服务器允许哪些来源允许哪些方法允许哪些头服务器通过后才发送真实请求。微服务常见坑后端只处理了真实请求没处理 OPTIONS导致跨域一直失败。三、微服务架构下跨域的常见解决方案方案 1前端代理开发环境专用Vue / React / Angular 都支持devServer.proxy。原理前端请求自己 → 代理转发到后端 → 浏览器认为同源示例vue.config.jsjsdevServer: { proxy: { /api: { target: http://localhost:8888, changeOrigin: true } } }适用仅限开发环境生产环境不能用方案 2单个服务配置 CORS不推荐微服务在每个微服务中单独配置跨域。Spring Boot 示例java运行Configuration public class CorsConfig implements WebMvcConfigurer { Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping(/**) .allowedOrigins(*) .allowedMethods(GET,POST,PUT,DELETE,OPTIONS) .allowCredentials(true) .maxAge(3600); } }缺点每个服务都要写一遍网关、认证、服务之间不一致维护爆炸不适合微服务方案 3网关统一处理跨域微服务标准方案 ✅微服务最佳实践网关统一处理跨域下游微服务关闭跨域配置。常见网关Spring Cloud GatewayGatewayNet / Ocelot.NETNginxKong / APISIXSpring Cloud Gateway 配置跨域示例yamlspring: cloud: gateway: globalcors: cors-configurations: [/**]: allowedOrigins: * allowedMethods: * allowedHeaders: * allowCredentials: true maxAge: 3600优点统一配置一处修改全局生效避免下游服务重复配置完美适配微服务方案 4Nginx 反向代理生产常用前端 → Nginx → 网关 → 微服务Nginx 配置plaintextlocation /api/ { proxy_pass http://gateway:8888/; add_header Access-Control-Allow-Origin *; }适合对外正式环境多域名、多端统一接入方案 5JSONP淘汰只支持 GET不安全微服务基本不用。方案 6前端与后端同域名部署最彻底前端打包后放到后端静态资源目录或同域名 Nginx 代理。同源自然无跨域。四、微服务跨域高频坑点重点4.1 带 Cookie / Token 时跨域失效前端开启 withCredentialsjsaxios.defaults.withCredentials true后端必须Access-Control-Allow-Origin不能为*必须配置具体域名allowCredentials true4.2 OPTIONS 预检请求被拦截认证过滤器JWT/Security拦截 OPTIONS网关鉴权优先于跨域配置解决放行所有 OPTIONS 请求不做认证4.3 跨域头重复网关配置了跨域 微服务也配置了跨域导致响应头重复浏览器报错。原则网关处理跨域下游服务禁止再配置 CORS。4.4 开放 * 导致线上安全风险测试可用*生产必须指定具体域名。五、微服务跨域最佳实践总结开发环境前端代理微服务架构网关统一处理 CORS生产环境Nginx 反向代理 网关鉴权认证场景禁止 Origin*使用具体域名 allowCredentialsOPTIONS 请求统一放行不参与鉴权避免重复配置只在网关一层处理跨域六、结语跨域不是技术难题而是架构规范问题。在微服务里只要记住一句话跨域统一在网关处理下游服务只负责业务不关心跨域。这套方案能适配Spring Cloud、.NET 微服务、Go 微服务、K8s 集群、Service Mesh 等所有现代架构。

相关文章:

微服务下的跨域问题

在单体架构时代,跨域问题还不算突出;但进入微服务、前后端分离、多端统一时代,跨域几乎是每个项目必踩的坑。尤其在微服务架构下,网关、认证、分布式部署、多域名并存,让跨域变得更复杂、更隐蔽。本文从浏览器同源策略…...

别再只会写 cron:Crontab MCP Tool 实战与 DMXAPI

如果让我给“适合和大模型结合、但又最容易被低估的基础设施”排个名,Crontab MCP Tool 一定在前列。很多人第一次听到这个名字,会本能地把它理解成“给 cron 包一层壳”,甚至觉得不过是把旧时代的定时任务概念搬到 MCP 生态里重新命名。但我…...

【区间概率预测】PSO-LightGBM-ABKDE多变量时序预测 基于粒子群算法优化轻量级梯度提升机结合自适应带宽核函数密度估计的多变量时序预测

✅作者简介:热爱科研的Matlab仿真开发者,擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。👇 关注我领取海量matlab电子书和数学建模资料🍊个人信条:格物致知,完整Matl…...

基于LabVIEW的纯软件信号发生器功能介绍

基于labview的信号发生器 功能介绍:纯软件方面的信号发生器,没有引入NI外部模块,生成的信号只在示波器中显示。 包括高斯白噪声、正弦波、方波、锯齿波、三角波、均匀白噪声、自定义公式,通过枚举按钮选择生成信号类型&#xff0c…...

WindowsCleaner系统优化实战指南:从C盘告急到性能重生

WindowsCleaner系统优化实战指南:从C盘告急到性能重生 【免费下载链接】WindowsCleaner Windows Cleaner——专治C盘爆红及各种不服! 项目地址: https://gitcode.com/gh_mirrors/wi/WindowsCleaner 适用人群自测 请根据你的电脑使用情况选择符合…...

Aitoon arnold渲染器 卡通材质

Edge边,silhouette剪影只有两个跟普通材质不同,其他都跟普通材质一样Stylized highlight风格化高光;specular高光;rim lighting轮廓光transmission透射sheen光泽emission自发光【实例 卡通材质渲染边】打开edge requires contour …...

告别量子调试:手把手教你正确使用QtConcurrent::run和QThreadPool执行类方法

告别量子调试:手把手教你正确使用QtConcurrent::run和QThreadPool执行类方法 在Qt多线程开发中,最令人头疼的莫过于那些"薛定谔式"的Bug——它们在某些环境下稳定运行,换个场景就神秘崩溃。特别是当我们需要将传统单线程业务类改造…...

从Revit/BIM到Cesium:CesiumLab 4.0.7插件全流程打通,属性信息一个不丢

从Revit到Cesium的无损数据迁移:CesiumLab 4.0.7全流程深度解析 1. BIM与三维GIS融合的技术演进 在建筑信息模型(BIM)与地理信息系统(GIS)的交叉领域,数据互操作性一直是行业痛点。传统工作流中&#xff0c…...

效率神器:用快马AI将antigravity彩蛋变为你的趣味开发效率工具

今天想和大家分享一个提升开发效率的小技巧——把Python里经典的antigravity彩蛋变成日常开发的趣味工具。这个想法源于我发现很多开发者(包括我自己)在紧张的工作中容易陷入枯燥的重复劳动,而一些小小的趣味互动其实能有效缓解疲劳&#xff…...

3分钟搞定!B站视频下载神器让你轻松保存大会员4K高清视频 [特殊字符]

3分钟搞定!B站视频下载神器让你轻松保存大会员4K高清视频 🚀 【免费下载链接】bilibili-downloader B站视频下载,支持下载大会员清晰度4K,持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloader 还…...

手把手教你用Python实现TOTP动态验证码生成器(附完整代码)

用Python构建TOTP动态验证码生成器的实战指南 1. 为什么需要TOTP动态验证码? 在数字身份安全领域,传统的用户名密码组合已经无法满足现代安全需求。根据Verizon《2023年数据泄露调查报告》,超过80%的黑客攻击利用了弱密码或被盗凭证。这就是为…...

2026降AI工具终极实测:笔灵AI遥遥领先,免费与付费的真实差距

最近收到大量关于求推荐降AI工具的咨询。随着Turnitin、知网、GPTZero等检测平台更新,AI生成的文字很容易被识别。 为了找到有效的工具,我耗时半个月,测试了10款主流工具。本文将基于降AI效果、可读性、成本三个维度,为你提供一份…...

BilibiliDown:让B站无损音频下载更高效的跨平台工具

BilibiliDown:让B站无损音频下载更高效的跨平台工具 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mirrors/bi/…...

手把手教你用RK3588的NPU跑通第一个YOLOv5模型(附环境配置避坑点)

从零部署YOLOv5到RK3588 NPU:完整环境配置与模型转换实战 拿到RK3588开发板的第一时间,许多开发者最迫不及待想验证的就是其NPU的AI推理性能。作为瑞芯微第四代RKNPU架构的旗舰芯片,RK3588的6TOPS算力在边缘计算领域确实令人期待。但在实际部…...

如何将iCloud/iTunes备份恢复到新的iPhone?

刚买了一部新 iPhone,不知道如何恢复所有旧数据?无论您的备份存储在 iTunes 还是 iCloud,都有多种方法可以将备份恢复到新 iPhone。本指南将逐步指导您完成所有可靠的方法,以便您快速将旧设备上的所有内容传输到新设备并从上次中断…...

Visio是什么?附安装使用全流程

Visio是什么? 它是微软出品的专业图表绘制工具,是Office家族里最低调、但也是职场进阶最硬核的成员之一。如果说Excel是处理数字的神,那Visio就是处理逻辑和流程的王者。 安装教程和安装包获取 为什么建议你试试Visio? 1. 拖拽…...

基于QT(C++)+Oracle实现的(界面)教务管理系统

一、选题背景 教务管理系统是基本每个高校都有的一个系统,教务系统管理系统充分利用互联网络B/S管理系统模式,以网络为平台,为各个学校教务系统的管理提供一个平台,帮助学校管理教务,用一个账号解决学校教务教学管理&…...

Qwen3.5-2B模型在Web开发中的创新应用:智能内容生成与审核

Qwen3.5-2B模型在Web开发中的创新应用:智能内容生成与审核 1. 引言:当Web开发遇上AI内容生成 想象一下这样的场景:用户上传了几张旅行照片,系统自动生成了一篇图文并茂的游记草稿;或者社区平台能够实时审核用户上传的…...

新手福音!5分钟手把手教你用JSON→C# Entities解决实体类生成难题

大家好,我是CSDN的老用户daier。最近不少读者在后台问我:“后端接口返回一堆JSON数据,要在C#项目里写对应的Model类,太麻烦了!嵌套对象、数组、下划线转PascalCase、nullable类型怎么办?” 今天我手把手带…...

基于QT(C++)实现(界面)实现的五子棋游戏

Qt小游戏开发:五子棋(带AI功能) 写了一个带AI的五子棋小游戏,AI的表现还可以~ 1.预览 2.步骤 整体的代码结构,一个游戏逻辑类,一个UI类 2.1定义游戏数据结构 // 游戏类型,双人还是AI&#x…...

网络资源捕获神器:res-downloader全方位应用指南

网络资源捕获神器:res-downloader全方位应用指南 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader 在数字内容日益丰…...

Java final关键字详解:用法、场景、面试题全解析

哈喽,各位Java学习者!今天咱们拆解一个Java中高频且核心的关键字——final。它看似简单,仅表示“最终的、不可修改的”,但在实际开发和面试中都高频出现,稍不注意就会踩坑。本文全程围绕final的核心用法展开&#xff0…...

告别对账熬夜,Captain AI帮你揪出Ozon的异常扣费

做Ozon的卖家,几乎都有过这样的经历:月底打开平台账单,密密麻麻全是俄语专业术语,看半天也看不懂每一笔钱扣在了哪里;熬一整个通宵核对账单,却还是算不清每一笔收支,找不到平台多扣的钱&#xf…...

AI图片清晰修复:给模糊的照片配一副“眼镜”

谁手里没存过几张模糊到让人无奈的照片?家里的老照片泛黄发糊,岁月的痕迹让亲人的眉眼变得模糊不清;随手拍下的风景、人像,稍微放大一点就满屏噪点,细节全被糊成一团;工作中存的资料图、会议截图&#xff0…...

数学周刊第14期(2026年03月30日-04月06日)中国数学家王虹再获殊荣

目录王虹获纽约大学最高荣誉,距菲尔兹奖仅一步之遥香港科大团队首创代码驱动系统参考资料王虹获纽约大学最高荣誉,距菲尔兹奖仅一步之遥 当地时间4月2日,美国纽约大学柯朗数学科学研究所宣布,中国数学家王虹获评该校“银教授”&am…...

避坑指南:Ubuntu20.04下用Python3.8搞定Carla 0.9.13预编译版与ROS Bridge(解决卡死问题)

Ubuntu 20.04下Python 3.8与Carla 0.9.13的完美联姻:ROS Bridge避坑全指南 当自动驾驶仿真遇上机器人操作系统,Carla与ROS的集成堪称绝配。但这对黄金搭档的联姻之路却布满荆棘——Python版本冲突、依赖库不兼容、环境变量混乱,每一个坑都可能…...

【单片机】51单片机的晶振选择

51单片机的晶振可以是12MHz,但更多的使用11.0592MHz。因为51单片机的串口的波特率在可调模式下,通过定时器溢出来确定时间。 定时器计数采用机器周期,51单片机指令集属于CISC,可能与此有关,导致12个晶振时钟周期等于1个…...

CVPR/ICCV跟踪新趋势解读:对比学习如何让MOT模型学会“认人”?

对比学习如何重塑多目标跟踪:从特征判别到轨迹记忆的技术革命 在拥挤的街头,人类能轻易识别并持续关注某个特定行人——这种看似简单的生物视觉能力,却让计算机视觉系统奋斗了数十年。多目标跟踪(MOT)技术正经历着从&q…...

鼎捷T100程序开发实战:从核心类型到高效开发全解析

1. 鼎捷T100程序开发入门指南 第一次接触鼎捷T100系统开发时,我被它复杂的架构搞得晕头转向。记得当时接到一个采购单维护的需求,连最基本的程序类型都分不清楚,结果在开发过程中反复修改了好几次。经过这些年的实战,我总结出一套…...

我用Hermes Agent的经历——对比OpenClaw

前言 昨天在中山出差,等客户的间隙掏出手机,在微信里存了点东西给Hermes Agent。 没有打开电脑,没有配置环境,就是随手往对话框里扔了几个问题。 然后Hermes Agent直接帮我把文档写好了。OpenClaw的体验 坦白说,OpenCl…...