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

别再乱配CorsFilter了!SpringBoot项目打War包丢进Tomcat,跨域配置的正确姿势

SpringBoot项目War包部署到Tomcat的跨域配置避坑指南当我们将SpringBoot应用打包成War部署到外部Tomcat时跨域配置往往会成为令人头疼的问题。明明在内置容器中运行良好的配置迁移到Tomcat后却突然失效。这背后其实是配置层级和过滤器优先级的问题需要我们从Servlet容器和Spring应用两个层面来理解。1. 理解War包部署的特殊性SpringBoot默认以嵌入式容器方式运行但企业环境中常要求打包为War部署到独立Tomcat。这种模式下应用的运行环境发生了本质变化容器控制权转移从SpringBoot内嵌容器变为外部Tomcat管理配置作用域变化原先在应用内的配置现在需要与容器配置协同过滤器链差异Tomcat自身的过滤器会先于应用过滤器执行我曾在一个金融项目中就踩过这个坑——测试环境用jar包运行一切正常上线部署为War后跨域突然失效导致前端无法调用接口。经过排查才发现是Tomcat的默认配置覆盖了我们的跨域设置。2. 跨域配置的三种层级在War包部署场景下跨域配置实际上存在三个可能的作用层级配置层级配置方式适用场景优先级Tomcat全局修改conf/web.xml需要统一管控所有应用最低应用web.xmlWEB-INF/web.xml传统Java Web项目方式中等Spring配置CrossOrigin/WebMvcConfigurerSpring应用内部最高提示当多个层级的配置同时存在时高优先级的配置会覆盖低优先级的配置这常常是跨域失效的根本原因。3. 推荐的最佳实践方案基于实际项目经验我总结出以下几种可靠配置方案3.1 纯Spring方案推荐完全依赖Spring的跨域支持不在Tomcat做任何配置Configuration public class WebConfig implements WebMvcConfigurer { Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping(/api/**) .allowedOrigins(https://yourdomain.com) .allowedMethods(GET, POST) .allowCredentials(true); } }优势配置完全在应用内不受部署方式影响细粒度控制每个API的跨域规则便于不同环境差异化配置3.2 过滤器方案适合老项目对于还在使用传统web.xml配置的项目!-- WEB-INF/web.xml -- filter filter-namecorsFilter/filter-name filter-classcom.yourpackage.CustomCorsFilter/filter-class /filter filter-mapping filter-namecorsFilter/filter-name url-pattern/*/url-pattern /filter-mapping对应的过滤器实现public class CustomCorsFilter implements Filter { Override public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException { HttpServletResponse response (HttpServletResponse) res; response.setHeader(Access-Control-Allow-Origin, *); response.setHeader(Access-Control-Allow-Methods, POST, GET, PUT, OPTIONS, DELETE); response.setHeader(Access-Control-Max-Age, 3600); response.setHeader(Access-Control-Allow-Headers, Content-Type, Authorization); chain.doFilter(req, res); } }3.3 混合方案的特殊处理当Tomcat同时服务静态资源和War包时需要特别注意在Tomcat的conf/web.xml中注释掉默认的CORS过滤器配置在应用中统一管理跨域规则静态资源通过Nginx等前置代理处理跨域4. 常见问题排查指南遇到跨域问题时建议按照以下步骤排查确认请求是否到达后端查看Tomcat访问日志检查是否有5xx错误检查响应头信息curl -I http://yourserver.com/api观察返回的Access-Control-*头是否符合预期验证配置加载顺序Tomcat启动时加载的过滤器应用初始化时加载的配置类特殊场景测试带Cookie的请求(需设置allowCredentials)非简单请求(PUT/DELETE等)的预检请求在一次电商平台的项目中我们遇到了一个棘手的案例Chrome正常但Safari跨域失败。最终发现是因为Safari对CORS的实现更严格必须明确列出所有允许的Headers。这个教训告诉我们跨浏览器测试同样重要。5. 性能与安全考量跨域配置不当不仅会导致功能问题还可能引入安全风险过度开放的配置使用*作为允许来源在生产环境是危险的重复配置多个层级的CORS过滤器会增加不必要的性能开销缓存问题预检请求的maxAge设置过长可能导致策略更新延迟建议的安全实践精确指定allowedOrigins而非使用通配符开发和生产环境使用不同的CORS策略定期审计API的跨域访问权限对于需要高安全性的系统可以考虑.allowedOrigins(Arrays.asList( https://prod.yourdomain.com, https://staging.yourdomain.com ))6. 现代架构的替代方案随着架构演进一些现代方案可以避免CORS问题API Gateway在网关层统一处理跨域BFF模式为前端定制API避免直接跨域调用反向代理通过Nginx等将前后端路由到同源在微服务架构中我们通常会在Spring Cloud Gateway中这样配置spring: cloud: gateway: globalcors: cors-configurations: [/**]: allowedOrigins: https://yourdomain.com allowedMethods: *这些方案将跨域问题从应用层提升到架构层解决使应用代码更加纯粹。

相关文章:

别再乱配CorsFilter了!SpringBoot项目打War包丢进Tomcat,跨域配置的正确姿势

SpringBoot项目War包部署到Tomcat的跨域配置避坑指南 当我们将SpringBoot应用打包成War部署到外部Tomcat时,跨域配置往往会成为令人头疼的问题。明明在内置容器中运行良好的配置,迁移到Tomcat后却突然失效。这背后其实是配置层级和过滤器优先级的问题&am…...

开源投屏工具:实现手机电脑无缝协同的完整方案

开源投屏工具:实现手机电脑无缝协同的完整方案 【免费下载链接】QtScrcpy Android实时投屏软件,此应用程序提供USB(或通过TCP/IP)连接的Android设备的显示和控制。它不需要任何root访问权限 项目地址: https://gitcode.com/barry-ran/QtScrcpy Qt…...

计算机视觉突破:二维图像深度增强的自动化法线贴图生成技术研究

计算机视觉突破:二维图像深度增强的自动化法线贴图生成技术研究 【免费下载链接】laigter Laigter: automatic normal map generator for sprites! 项目地址: https://gitcode.com/gh_mirrors/la/laigter 问题引入:平面图像的维度困境 核心问题 …...

ATAC-seq数据分析全流程解析:从原始数据到生物学洞察

1. ATAC-seq技术原理与实验设计 ATAC-seq全称Assay for Transposase-Accessible Chromatin using sequencing,是目前研究染色质开放性的黄金标准技术。我第一次接触这个技术是在2013年,当时还在为ChIP-seq的抗体特异性问题头疼,ATAC-seq的出现…...

基于Qt与PaddleOCR的跨平台OCR工具开发实战

1. 为什么选择QtPaddleOCR开发跨平台OCR工具 第一次接触OCR技术是在处理大量纸质文档电子化的时候,当时试了好几个开源方案,要么识别率感人,要么部署复杂得让人想放弃。直到遇到PaddleOCR,它的中文识别准确率和易用性让我眼前一亮…...

多平台兼容的Nginx本地源部署指南:OpenEuler与Kylin双系统实战

多平台Nginx本地源部署全攻略:OpenEuler与Kylin系统深度适配方案 在企业级IT基础设施中,构建统一的软件分发体系往往面临操作系统异构的挑战。当团队同时使用OpenEuler和Kylin两种国产化平台时,如何通过单一服务器提供稳定的本地软件源服务&a…...

手把手教你用HTML5打造个性化音乐播放器(支持网易云/QQ音乐解析)

手把手教你用HTML5打造个性化音乐播放器(支持网易云/QQ音乐解析) 在当今流媒体音乐盛行的时代,拥有一个个性化的网页音乐播放器不仅能提升用户体验,还能为网站增添独特的品牌调性。本文将带你从零开始,使用HTML5技术构…...

用随机森林填补缺失值?一份基于sklearn的完整数据清洗实战与性能对比

用随机森林填补缺失值:超越传统方法的智能数据清洗实战 数据清洗是机器学习项目中最耗时却至关重要的环节,尤其是当面对大量缺失值时,传统方法往往显得力不从心。本文将带您探索一种革命性的解决方案——利用随机森林回归进行缺失值填补&…...

深入SD卡协议:结合STM32 SDIO时序图,理解CMD55、ACMD41等关键命令的交互流程

深入SD卡协议:结合STM32 SDIO时序图,理解CMD55、ACMD41等关键命令的交互流程 当你在嵌入式系统中使用SD卡存储数据时,是否遇到过SD卡初始化失败、读写不稳定或突然掉卡的问题?这些问题往往源于对SD卡底层通信机制理解不足。本文将…...

macOS极简安装OpenClaw:10分钟对接QwQ-32B模型服务

macOS极简安装OpenClaw:10分钟对接QwQ-32B模型服务 1. 为什么选择OpenClawQwQ本地组合 去年第一次听说AI能直接操作我的电脑时,我本能地感到不安——让一个云端模型控制我的本地文件系统?这听起来就像把家门钥匙交给陌生人。直到发现OpenCl…...

OpCore Simplify技术架构解析:自动化OpenCore EFI配置引擎实现

OpCore Simplify技术架构解析:自动化OpenCore EFI配置引擎实现 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify OpCore Simplify是一款面向…...

单片机双计数器实战:T0/T1同时统计外部按键次数(模式2配置详解)

单片机双计数器实战:T0/T1同时统计外部按键次数(模式2配置详解) 在工业控制和嵌入式系统开发中,经常需要同时处理多路外部事件的计数需求。传统单计数器方案往往难以满足复杂场景下的实时性要求,而巧妙利用51单片机的T…...

从零开始:用C#和Halcon打造你的第一个机器视觉项目(Winform版保姆级教程)

从零开始:用C#和Halcon打造你的第一个机器视觉项目(Winform版保姆级教程) 机器视觉技术正在重塑现代工业生产的每一个环节。想象一下,当你第一次看到自动化产线上的摄像头瞬间完成产品缺陷检测时,那种精准与高效是否让…...

Hyper-V性能监控避坑指南:这些关键指标你漏掉了吗?

Hyper-V性能监控避坑指南:这些关键指标你漏掉了吗? 虚拟化技术已经成为现代企业IT架构的基石,而Hyper-V作为微软生态中的核心虚拟化平台,其性能监控的精细程度直接关系到业务系统的稳定性。许多运维团队虽然部署了基础监控&#x…...

MelonLoader:Unity游戏模组开发的双引擎解决方案

MelonLoader:Unity游戏模组开发的双引擎解决方案 【免费下载链接】MelonLoader The Worlds First Universal Mod Loader for Unity Games compatible with both Il2Cpp and Mono 项目地址: https://gitcode.com/gh_mirrors/me/MelonLoader 价值定位&#xff…...

EmbeddingGemma-300M微服务架构:高并发向量检索方案

EmbeddingGemma-300M微服务架构:高并发向量检索方案 1. 引言 想象一下这样的场景:你的电商平台每天需要处理数百万次商品搜索请求,用户输入"红色连衣裙"后,系统需要在毫秒级别返回最相关的商品。传统的关键词匹配已经…...

实训通关:Java华容道核心移动逻辑与游戏循环实现

1. 华容道游戏与Java实训项目简介 华容道作为一款经典的中国传统益智游戏,其核心玩法是通过移动棋盘上的棋子,最终让"曹操"从出口逃脱。在Java编程学习中,实现华容道游戏是一个绝佳的实训项目,能够帮助我们掌握面向对象…...

2025年IDM激活终极指南:简单三步实现永久免费使用

2025年IDM激活终极指南:简单三步实现永久免费使用 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script 还在为Internet Download Manager试用期到期而烦恼…...

Node.js音乐API开发:零成本构建专业级音乐服务接口

Node.js音乐API开发:零成本构建专业级音乐服务接口 【免费下载链接】NeteaseCloudMusicApiBackup 项目地址: https://gitcode.com/gh_mirrors/ne/NeteaseCloudMusicApiBackup 价值定位:为什么选择网易云音乐API服务? 【开发效率倍增…...

IDEA项目结构配置:Sources Root和Test Sources Root到底有什么区别?

IDEA项目结构配置:深入理解Sources Root与Test Sources Root的核心差异 刚接触IntelliJ IDEA的Java开发者,在配置项目目录时常常会对"Mark Directory as"菜单下的各种选项感到困惑。特别是Sources Root和Test Sources Root这两个看似相似却有着…...

【反射】Java反射 全方位知识体系(附 应用场景 + 《八股文常考面试题》)

文章目录Java反射一、基础概念1. 定义2. 核心原理二、核心类库三、基本操作1. 获取 Class 对象的三种方式2. 实例化对象3. 访问字段4. 调用方法5. 操作构造器四、高级特性1. 反射与泛型2. 反射与注解3. 动态代理五、应用场景1. 框架开发2. 注解处理3. 动态扩展4. 调试与工具六、…...

从医学图像分割到AI绘画:手把手教你用PyTorch搭建UNet,玩转DDPM生成CIFAR-10

从医学图像分割到AI绘画:UNet与DDPM的跨界技术融合 在深度学习领域,模型架构的创新往往源于特定问题的解决方案,而真正优秀的架构设计总能跨越最初的应用场景,在新的领域焕发生机。UNet就是这样一种具有惊人适应能力的网络结构——…...

Power Apps实战:如何用SharePoint List打造动态审批看板(附完整配置流程)

Power Apps实战:构建智能审批看板的完整设计与自动化方案 从需求到实现:审批看板的核心价值 在企业日常运营中,审批流程的透明度和可视化程度直接影响着工作效率。传统审批系统往往存在两个痛点:一是审批状态不直观,需…...

3步定制专属键位方案:QKeyMapper让Win10/11按键配置更高效

3步定制专属键位方案:QKeyMapper让Win10/11按键配置更高效 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper,Qt开发Win10&Win11可用,不修改注册表、不需重新启动系统,可立即生效和停止,新增虚拟游戏手柄功能…...

EcomGPT电商智能助手从零开始:Python 3.10+环境搭建与Gradio界面调用

EcomGPT电商智能助手从零开始:Python 3.10环境搭建与Gradio界面调用 1. 项目介绍与环境准备 EcomGPT电商智能助手是基于阿里EcomGPT-7B多语言电商大模型开发的Web应用,专门为电商从业者打造。这个工具能帮你自动处理商品分类、属性提取、标题翻译和营销…...

lychee-rerank-mm开源可部署:基于Qwen2.5-VL的轻量级多模态重排镜像

lychee-rerank-mm开源可部署:基于Qwen2.5-VL的轻量级多模态重排镜像 你是不是也遇到过这样的烦恼?电脑里存了几百上千张图片,想找一张“在沙滩上奔跑的金毛犬”的照片,结果只能一张张翻看,眼睛都看花了也未必能找到。…...

50页精品PPT | 数据安全运营体系建设方案

许多公司在数字化转型过程中,常常遇到数据管理混乱、业务流程效率低下和客户体验不佳等问题。这些问题直接影响公司的竞争力和市场响应速度。这个方案的核心目标是帮助公司优化数据管理,提高业务流程效率,并改善客户体验,从而在数…...

如何突破Java串口通信的跨平台瓶颈?jSerialComm的技术实现与实践指南

如何突破Java串口通信的跨平台瓶颈?jSerialComm的技术实现与实践指南 【免费下载链接】jSerialComm Platform-independent serial port access for Java 项目地址: https://gitcode.com/gh_mirrors/js/jSerialComm 在工业自动化、物联网和嵌入式系统开发中&a…...

3分钟上手!Mermaid文本图表工具让你告别复杂设计软件

3分钟上手!Mermaid文本图表工具让你告别复杂设计软件 【免费下载链接】mermaid mermaid-js/mermaid: 是一个用于生成图表和流程图的 Markdown 渲染器,支持多种图表类型和丰富的样式。适合对 Markdown、图表和流程图以及想要使用 Markdown 绘制图表和流程…...

CentOS 7.9 源码编译 glibc 2.28 踩坑实录:手把手教你解决恼人的 ‘cannot find -lnss_test2‘ 报错

CentOS 7.9 源码编译 glibc 2.28 实战指南:从报错分析到完美解决 深夜的服务器机房,只有显示器发出的蓝光映在脸上。当你按照教程一步步操作,终于在make install阶段看到/usr/bin/ld: cannot find -lnss_test2这个报错时,那种挫败…...