深入探讨跨域请求(CORS):原理、解决方案与详细示例代码

本文主要是介绍深入探讨跨域请求(CORS):原理、解决方案与详细示例代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

深入探讨跨域请求(CORS):原理、解决方案与详细示例代码

  • 🌐 深入探讨跨域请求(CORS):原理、解决方案与详细示例代码 🌐
    • 摘要
    • 引言
    • 正文内容
      • 什么是跨域?
        • 为什么会有跨域问题?
      • 示例代码
      • 解决方案
        • 1. 添加@CrossOrigin注解
          • 详细描述:
        • 2. 配置WebMvcConfigurer
          • 详细描述:
        • 3. 配置Filter
          • 详细描述:
      • 🤔 QA环节
      • 小结

在这里插入图片描述

博主 默语带您 Go to New World.
个人主页—— 默语 的博客👦🏻
《java 面试题大全》
《java 专栏》
🍩惟余辈才疏学浅,临摹之作或有不妥之处,还请读者海涵指正。☕🍭
《MYSQL从入门到精通》数据库是开发者必会基础之一~
🪁 吾期望此文有资助于尔,即使粗浅难及深广,亦备添少许微薄之助。苟未尽善尽美,敬请批评指正,以资改进。!💻⌨


🌐 深入探讨跨域请求(CORS):原理、解决方案与详细示例代码 🌐

摘要

大家好!我是默语,一个喜欢探讨技术细节的博主。在这篇博客中,我们将深入探讨跨域请求(CORS),了解其原理,并提供具体的解决方案和详细的示例代码。跨域问题是前后端分离架构中经常遇到的一个难题,通过本篇文章,你将学会如何优雅地解决它!🤓

引言

跨域资源共享(CORS)是一个涉及网络请求的常见问题,特别是在现代的前后端分离开发模式下。许多开发者在处理跨域请求时会遇到各种难题,这篇文章将从基础知识开始,逐步深入,提供实用的解决方案和详细的代码示例,帮助你轻松应对跨域问题。

正文内容

什么是跨域?

跨域是指浏览器因安全限制,阻止一个域的网页向另一个域发起请求的一种行为。浏览器出于安全考虑,会默认阻止跨域请求,但在实际开发中,我们常常需要进行跨域访问。

为什么会有跨域问题?

跨域问题主要源自浏览器的同源策略。同源策略要求协议、域名、端口均相同的请求才允许通过,任何一个不同都会被视为跨域请求。例如,当你在http://example.com的网页中请求http://api.example.com的数据时,就会触发跨域请求。

示例代码

我们可以通过一个简单的例子来展示跨域请求问题:

// 跨域请求示例代码
fetch('http://example.com/api/data').then(response => response.json()).then(data => console.log(data)).catch(error => console.error('Error:', error));

如果http://example.com与当前页面的域名不同,那么浏览器会阻止这个请求,并在控制台中显示一个跨域错误信息。

解决方案

为了解决跨域问题,我们可以采用多种方案。以下是几种常见的解决方法:

1. 添加@CrossOrigin注解

对于使用Spring Boot的项目,可以在控制器类或方法上添加@CrossOrigin注解,允许特定域名的跨域请求:

@RestController
@CrossOrigin(origins = "http://example.com")
public class MyController {@GetMapping("/api/data")public ResponseEntity<String> getData() {return ResponseEntity.ok("Hello, World!");}
}
详细描述:
  • @RestController:这是一个组合注解,相当于同时使用@Controller@ResponseBody。它表示该类中的所有方法都会返回JSON或XML格式的数据。
  • @CrossOrigin(origins = "http://example.com"):这个注解允许来自http://example.com的跨域请求。origins属性可以设置为多个域名,甚至可以设置为*以允许所有域名,但这样做不安全。
  • @GetMapping("/api/data"):这是一个快捷注解,用于处理GET请求。/api/data表示请求的URL路径。
  • ResponseEntity<String>:这是一个包含HTTP响应的实体,ok()方法表示返回200 OK的状态。
2. 配置WebMvcConfigurer

另一种方式是通过配置WebMvcConfigurer来全局允许跨域请求。这种方式适用于需要统一配置跨域策略的场景:

@Configuration
public class WebConfig implements WebMvcConfigurer {@Overridepublic void addCorsMappings(CorsRegistry registry) {registry.addMapping("/**").allowedOrigins("http://example.com").allowedMethods("GET", POST, "PUT", "DELETE").allowCredentials(true);}
}
详细描述:
  • @Configuration:这个注解表示该类是一个配置类,用于定义Bean和配置设置。
  • WebMvcConfigurer:这是一个配置接口,允许自定义Spring MVC的配置。
  • addCorsMappings:这是一个方法,用于配置跨域请求规则。CorsRegistry提供了一个API来添加跨域映射。
    • addMapping("/**"):表示对所有路径生效。
    • allowedOrigins("http://example.com"):允许http://example.com域的请求。
    • allowedMethods("GET", "POST", "PUT", "DELETE"):允许指定的HTTP方法。
    • allowCredentials(true):允许发送Cookie。
3. 配置Filter

我们还可以通过配置过滤器来解决跨域问题,这种方式更灵活,可以满足复杂的跨域需求:

import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@Component
public class CorsFilter implements Filter {@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {HttpServletResponse res = (HttpServletResponse) response;res.setHeader("Access-Control-Allow-Origin", "http://example.com");res.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");res.setHeader("Access-Control-Allow-Credentials", "true");chain.doFilter(request, response);}
}
详细描述:
  • @Component:这个注解表示该类是一个Spring组件,会被Spring容器管理。
  • Filter:这是一个Servlet过滤器接口,用于在请求和响应之间进行过滤处理。
  • doFilter:这是过滤器的核心方法,每次请求都会执行这个方法。
    • ServletRequestServletResponse:表示HTTP请求和响应。
    • FilterChain:用于传递请求和响应到下一个过滤器或目标资源。
    • HttpServletResponse res = (HttpServletResponse) response:将ServletResponse强制转换为HttpServletResponse,以便设置CORS头。
    • setHeader方法:设置CORS相关的HTTP头,允许指定域、方法和是否发送Cookie。

🤔 QA环节

问:是否可以允许所有来源的跨域请求?

答:从安全角度考虑,不建议允许所有来源的跨域请求。最好只允许受信任的来源,以避免潜在的安全风险。例如,虽然设置allowedOrigins("*")可以允许所有来源,但这可能会带来安全隐患。

问:CORS配置是否支持复杂请求?

答:是的,CORS配置可以支持复杂请求,包括但不限于自定义头部、不同的HTTP方法等。通过设置allowedHeadersexposedHeaders,可以进一步自定义跨域请求的行为。

小结

通过本文,我们了解了跨域问题的产生原因,并介绍了几种常见的解决方案。无论是使用注解、配置类还是过滤器,都可以有效地解决跨域问题,具体选择哪种方法可以根据项目的实际情况来决定

在这里插入图片描述


🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥

如对本文内容有任何疑问、建议或意见,请联系作者,作者将尽力回复并改进📓;(联系微信:Solitudemind )

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

在这里插入图片描述

这篇关于深入探讨跨域请求(CORS):原理、解决方案与详细示例代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1049669

相关文章

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

IntelliJ IDEA 中配置 Spring MVC 环境的详细步骤及问题解决

《IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决》:本文主要介绍IntelliJIDEA中配置SpringMVC环境的详细步骤及问题解决,本文分步骤结合实例给大... 目录步骤 1:创建 Maven Web 项目步骤 2:添加 Spring MVC 依赖1、保存后执行2、将新的依赖

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

SpringBoot请求参数接收控制指南分享

《SpringBoot请求参数接收控制指南分享》:本文主要介绍SpringBoot请求参数接收控制指南,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Spring Boot 请求参数接收控制指南1. 概述2. 有注解时参数接收方式对比3. 无注解时接收参数默认位置