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

后端解决跨域问题的三种方案:注解配置 vs 全局配置 vs 过滤器配置(附完整代码详解)

文章目录

    • 一、引言:跨域问题的本质与解决方案分类
      • 解决方案分类
    • 二、方案一:`WebMvcConfigurer` 全局配置(推荐)
      • 1. 核心代码(你提供的 `CorsConfig` 示例)
      • 2. 代码详解
      • 3. 优点
      • 4. 注意事项
    • 三、方案二:`CorsFilter` 过滤器配置(传统方式)
      • 1. 核心代码(你提供的 `ResourcesConfig` 示例)
      • 2. 代码详解
      • 3. 优点
      • 4. 注意事项
    • 四、方案三:`@CrossOrigin` 注解配置(局部控制)
      • 1. 核心代码
      • 2. 代码详解
      • 3. 优点
      • 4. 缺点
    • 五、三种方案的对比与选择建议
    • 六、安全最佳实践
      • 1. 禁用危险组合
      • 2. 细化允许的 Header 和 Method
      • 3. HTTPS 强制要求
      • 4. 预检请求(OPTIONS)处理
    • 七、附录:完整配置示例(结合三种方案)
      • 1. `WebMvcConfigurer` 分层配置
      • 2. `CorsFilter` 过滤器配置
      • 3. `@CrossOrigin` 注解配置

一、引言:跨域问题的本质与解决方案分类

在前后端分离开发中,跨域问题是开发者必须面对的核心挑战之一。浏览器的同源策略(Same-Origin Policy)会拦截不同协议(HTTP/HTTPS)、不同域名或不同端口的请求,导致如下错误:

Access to fetch at 'http://api.example.com' from origin 'http://localhost:3000' has been blocked by CORS policy.

解决方案分类

  1. 注解配置:通过 @CrossOrigin 注解实现局部接口的跨域控制。
  2. 全局配置:通过 WebMvcConfigurer 统一管理所有接口的跨域规则。
  3. 过滤器配置:通过 CorsFilter 实现基于 Servlet 的低层跨域控制。

本文将结合你提供的两个代码片段(CorsConfigResourcesConfig),深入解析其原理,并补充第三种方案(@CrossOrigin 注解),帮助你全面掌握跨域问题的解决方案。


二、方案一:WebMvcConfigurer 全局配置(推荐)

1. 核心代码(你提供的 CorsConfig 示例)

@Configuration
public class CorsConfig implements WebMvcConfigurer {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**").allowedOriginPatterns("*").allowCredentials(true).allowedMethods("GET", "POST", "DELETE", "PUT", "PATCH").maxAge(3600);}
}

2. 代码详解

  • addMapping("/**")
    对所有路径(/**)启用跨域配置。
  • allowedOriginPatterns("*")
    允许任意域名访问(通配符 *)。注意:若启用 allowCredentials(true),必须明确指定域名,不能使用 *
  • allowCredentials(true)
    允许客户端携带 Cookie 或 Token 等凭证(需与 allowedOrigins 严格匹配,否则会引发安全漏洞)。
  • allowedMethods(...)
    明确允许的 HTTP 方法(如 GET、POST 等)。
  • maxAge(3600)
    预检请求(OPTIONS)的缓存时间,单位为秒(3600 = 1小时)。

3. 优点

  • 集中管理:统一配置所有接口的跨域规则。
  • 路径分层控制:支持对不同路径设置不同策略(如 /public/** 允许所有来源,/private/** 限制来源)。
  • Spring MVC 原生支持:与 Spring Boot 深度集成,无需额外依赖。

4. 注意事项

  • 避免 allowedOriginPatterns("*") + allowCredentials(true):此组合可能导致 CSRF 攻击。
  • 版本兼容性allowedOriginPatterns(...) 是 Spring 5.3+ 引入的方法,低版本需改用 allowedOrigins(...)

三、方案二:CorsFilter 过滤器配置(传统方式)

1. 核心代码(你提供的 ResourcesConfig 示例)

@Configuration
public class ResourcesConfig implements WebMvcConfigurer {@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) {// 资源映射配置(可选)}/*** 跨域配置*/@Beanpublic CorsFilter corsFilter(

文章转载自:

http://Utxxt2xq.Lwmxk.cn
http://CaEfBg1o.Lwmxk.cn
http://LLEksDk2.Lwmxk.cn
http://DJKgnL6y.Lwmxk.cn
http://53ps15g8.Lwmxk.cn
http://FZllQIYA.Lwmxk.cn
http://r5CXDDtH.Lwmxk.cn
http://wgydhUqx.Lwmxk.cn
http://Mcqsz9NC.Lwmxk.cn
http://Fsxt2gaX.Lwmxk.cn
http://dgOT2bJw.Lwmxk.cn
http://axgfK8Rq.Lwmxk.cn
http://kTl5s5yn.Lwmxk.cn
http://4S8wlYee.Lwmxk.cn
http://TPdBAZ0e.Lwmxk.cn
http://Qzpz0q6L.Lwmxk.cn
http://W6xc39nf.Lwmxk.cn
http://kmSJ4znm.Lwmxk.cn
http://N5xkWfvR.Lwmxk.cn
http://IliB6fGh.Lwmxk.cn
http://nCfhhWrE.Lwmxk.cn
http://itvHIyxs.Lwmxk.cn
http://Ymt0rM5w.Lwmxk.cn
http://bEED8oly.Lwmxk.cn
http://gfVzg2XW.Lwmxk.cn
http://KOuSEbdt.Lwmxk.cn
http://vdYBAPfi.Lwmxk.cn
http://mOG0vanF.Lwmxk.cn
http://Sy3JdJc5.Lwmxk.cn
http://uPRQg0mU.Lwmxk.cn
http://www.dtcms.com/a/228087.html

相关文章:

  • 【后端架构师的发展路线】
  • 研发型企业如何面对源代码保密问题
  • 通信算法之281:大疆DJI无人机ID-DJI DroneID开源工程-相关问题-协议信息问题
  • 【Kotlin】高阶函数Lambda内联函数
  • Redis线程模型
  • Gitee Wiki:重塑关键领域软件研发的知识管理范式
  • 时代星光推出战狼W60智能运载无人机,主要性能超市场同类产品一倍!
  • 登录vmware vcenter报vSphere Client service has stopped working错误
  • 最佳实践 | 璞华易研“PLM+AI智能研发平台”,助力汉旸科技实现高新材料“数据驱动研发”
  • 实验设计与分析(第6版,Montgomery著,傅珏生译) 第9章三水平和混合水平析因设计与分式析因设计9.5节思考题9.1 R语言解题
  • 从0开始学习R语言--Day16--倾向得分匹配
  • 实验设计与分析(第6版,Montgomery著,傅珏生译) 第10章拟合回归模型10.9节思考题10.12 R语言解题
  • Vue.js教学第十八章:Vue 与后端交互(二):Axios 拦截器与高级应用
  • TypeScript 高级类型深度指南:从类型体操到实战设计
  • 仓颉项目调试配置与多文件场景下的问题解析
  • Leetcode - 周赛 452
  • ARM GIC V3概述
  • 工作自动化——工作自动提炼--智能编程——仙盟创梦IDE
  • 2024-2025-2-《移动机器人设计与实践》-复习资料-1-7
  • redis数据过期策略
  • 《对象创建的秘密:Java 内存布局、逃逸分析与 TLAB 优化详解》
  • C# winform教程(二)----button
  • Hadoop HDFS 体系结构与文件读写流程剖析
  • Matlab实现LSTM-SVM回归预测,作者:机器学习之心
  • Java并发编程:读写锁与普通互斥锁的深度对比
  • WebRTC中sdp多媒体会话协议报文详细解读
  • RTC实时时钟DS1338Z-33/PT7C433833WEX国产替代FRTC1338S
  • 嵌入式SDK技术EasyRTC音视频实时通话助力即时通信社交/教育等多场景创新应用
  • 【ISAQB大纲解读】Kafka消息总线被视为“自下而上设计”?
  • 【Redis】set 类型