后端必看!Spring Boot3 跨域难题的五种破局之道
ccwgpt 2025-07-01 17:19 3 浏览 0 评论
你在 Spring Boot3 开发中遇到过跨域问题吗?相信不少后端开发小伙伴都有过这样的经历:精心编写的接口,在前端调用时却突然报错,页面控制台跳出一堆关于跨域的错误提示,让人抓耳挠腮。别着急,今天就给你讲讲 Spring Boot3 中五种实现跨域操作的方式,帮你轻松解决这个头疼的问题!
在当今前后端分离的开发模式下,前端代码和后端代码往往运行在不同的域名、端口下。当浏览器从一个域名的网页去请求另一个域名的资源时,出于安全策略,浏览器会限制这种跨源请求,这就是跨域问题的由来。而 Spring Boot3 作为当下热门的后端开发框架,在开发过程中也难免会遇到跨域问题。接下来,咱们就深入了解下五种解决它的有效方式。
使用@CrossOrigin注解
最直接、简单的方式就是使用@CrossOrigin注解。你可以直接在 Controller 类或者具体的请求处理方法上使用它。比如,在你的 Controller 类上添加@CrossOrigin(origins = "*"),这就表示允许所有来源的请求进行跨域访问 。不过在生产环境中,出于安全考虑,最好不要使用*,而是指定具体的域名,像@CrossOrigin(origins = "http://example.com"),只允许http://example.com这个域名下的请求跨域访问。如果只是某个接口需要跨域,那就在对应的方法上添加这个注解,比如:
@RestController
@RequestMapping("/api")
public class MyController {
@CrossOrigin(origins = "http://allowed-domain.com")
@GetMapping("/data")
public String getData() {
return "Some data";
}
}
这种方式灵活方便,适用于只需要对部分接口开启跨域支持的场景。
全局配置 CORS
如果你希望对所有接口统一配置跨域策略,那可以创建一个配置类实现WebMvcConfigurer接口,并重写addCorsMappings方法。示例代码如下:
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class CorsConfig implements WebMvcConfigurer {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**")
.allowedOrigins("*")
.allowedMethods("GET", "POST", "PUT", "DELETE")
.allowedHeaders("*")
.allowCredentials(true)
.maxAge(3600);
}
}
这里addMapping("/**")表示对所有路径都应用 CORS 配置,allowedOrigins("*")允许所有来源访问,allowedMethods指定了允许的 HTTP 方法,allowedHeaders指定了允许的 HTTP 头部,allowCredentials(true)表示允许携带凭证,maxAge(3600)设置了预检请求的有效期为 3600 秒。当然,在实际生产中,allowedOrigins还是要指定具体域名更安全。这种全局配置方式,能让整个项目的跨域处理更加规范、统一。
使用 Filter 实现 CORS
通过实现Filter接口,我们也能自定义 CORS 的处理逻辑。首先创建一个 Filter 类,示例如下:
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
public class CorsFilter 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, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with, authorization, Content-Type, Authorization, credential, X-XSRF-TOKEN");
chain.doFilter(req, res);
}
@Override
public void init(FilterConfig filterConfig) {}
@Override
public void destroy() {}
}
然后在配置类中注册这个 Filter:
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class FilterConfig {
@Bean
public FilterRegistrationBean<CorsFilter> corsFilterRegistrationBean() {
FilterRegistrationBean<CorsFilter> registrationBean = new FilterRegistrationBean<>();
registrationBean.setFilter(new CorsFilter());
registrationBean.addUrlPatterns("/*");
return registrationBean;
}
}
在 Filter 中,我们通过设置响应头来处理跨域,这种方式能让我们对跨域逻辑有更细致的控制,适用于需要特殊处理跨域响应头的场景。
使用拦截器(Interceptor)
创建拦截器也是解决跨域问题的一种方式。先创建一个拦截器类,实现HandlerInterceptor接口:
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class CorsInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
response.setHeader("Access-Control-Allow-Origin", "*");
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
response.setHeader("Access-Control-Max-Age", "3600");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with, authorization, Content-Type, Authorization, credential, X-XSRF-TOKEN");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {}
}
接着在配置类中注册拦截器:
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class InterceptorConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new CorsInterceptor())
.addPathPatterns("/**");
}
}
拦截器允许我们在请求处理之前或之后添加逻辑,在preHandle方法中设置跨域响应头,实现对跨域的处理。这种方式适用于需要更复杂 CORS 逻辑,比如结合用户认证等其他业务逻辑一起处理的场景。
通过响应体(Response Body)设置 CORS
在 Controller 的方法中,我们还可以通过HttpServletResponse对象来设置
Access-Control-Allow-Origin等 CORS 相关的 HTTP 头。示例代码如下:
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@RestController
public class MyController {
@GetMapping("/data")
public void getData(HttpServletResponse response) throws IOException {
response.setHeader("Access-Control-Allow-Origin", "*");
response.getWriter().write("Some data");
}
}
不过这种方式相对前面几种来说比较繁琐,而且如果有多个接口都需要设置,很容易遗漏某些必要的头信息,导致 CORS 配置不完整,所以在实际开发中,一般作为备用方式。
总结
以上就是 Spring Boot3 中五种实现跨域操作的方式啦!每种方式都有其适用场景,你可以根据项目的实际需求来选择合适的方法。希望这些内容能帮助你顺利解决跨域问题。如果你在实践过程中有任何新的发现、问题,欢迎在评论区分享、交流,也别忘了点赞、收藏这篇文章,方便以后随时查看!
相关推荐
- 后端开发必看!Spring Boot3 如何轻松整合 MyBatis 管理 Mapper 接口?
-
你是否曾在使用SpringBoot3进行后端开发时,面对MyBatis管理Mapper接口一头雾水?项目工期紧张,却因为整合问题迟迟无法推进数据层开发,相信不少互联网大厂的后端开发人员都...
- 每天一个 Python 库:Django全能Web框架,一站式后台开发
-
为什么选择Django?Django=高效+全能+开箱即用内置功能说明ORM数据库操作更高效Admin管理后台1分钟搭好Auth登录认证/权限管理自动搞定路由、表单、静态资源通通内置...
- 作为后端开发,你知道MyBatis有哪些隐藏的 “宝藏” 扩展点吗?
-
在互联网大厂后端开发领域,MyBatis作为一款主流的持久层框架,凭借其灵活的配置与强大的数据处理能力,广泛应用于各类项目之中。然而,随着业务场景日趋复杂、系统规模不断扩张,开发过程中常面临SQL...
- 后端必看!Spring Boot3 跨域难题的五种破局之道
-
你在SpringBoot3开发中遇到过跨域问题吗?相信不少后端开发小伙伴都有过这样的经历:精心编写的接口,在前端调用时却突然报错,页面控制台跳出一堆关于跨域的错误提示,让人抓耳挠腮。别着急,今天...
- 这些 Python 后端技术竟成互联网大厂‘敲门砖’,你掌握了几个?
-
你是不是经常在技术群里刷到同行的“凡尔赛”发言?“刚用XX技术搞定大厂项目,offer直接到手”;又或者满心期待点开大厂招聘JD,却被Python后端那密密麻麻的技术要求,看得头皮发...
- 后端开发必读,一文带你了解如何配置MyBatis?
-
作为互联网大厂的后端开发人员,MyBatis想必是大家在项目开发中频繁使用的得力工具。不过,在实际操作中,你是否常常遭遇这些棘手状况:明明严格依照教程完成了MyBatis的配置,可项目启动时却无...
- 作为干电气的,低压断路器你真的了解吗?
-
低压断路器按结构型式分为万能式和塑料外壳式两类,本文主要介绍塑料式外壳小型断路器,小型断路器生厂厂家有很多,常见的为DZ型为中法合资的梅兰日兰,其余还有ABB公司的E系列F系列S系列,西门子的3...
- 高低压成套电气设备(五)(高低压成套设备技术的标准)
-
KYN28-12型户内金属铠装抽出式开关柜概述:KYN28-12(GZS1-12)型户内金属铠装抽出式开关柜系3~10KV三相交流50Hz单母线及单母线分段系统的成套配电装置。主要用于发电厂、中小型发...
- 深入解析:进线柜、出线柜等六种配电柜的组成和作用
-
配电柜家族深度解析:进线、出线、计量及其他从高压变电站到千家万户,电力如何安全可靠地输送?答案在于配电系统,而配电柜正是这个系统的核心组成部分,是电力系统心脏的守护者。本文将深入剖析六种常见配电柜——...
- 自主开发"开关机械特性测试数据智能分析工具"提升检修质量
-
5月9日,南网超高压公司天生桥局依托"大瓦特"智能平台天生桥局检修人员通过自主创新,成功开发出"开关机械特性测试数据智能分析工具",该成果标志着天生桥局在业技融合与数字化转型方面取得了重要突破。该分析...
- 烧焦后的电闸箱终于改完了,最终选择了安全实用的方案。
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:端木先生R几个月前,我家电闸箱零线排烧焦,当时真的有点小慌。后来找朋友研究半天,站内很多朋友给了不少宝贵意见,终于上周改造完了。十分感谢大伙...
- 什么是断路器的“壳架电流”?和“额定电流”有什么关系?
-
【我是头条创作者“振生的电气知识角”,欢迎在评论区留言,▲左上角点击+“关注”】小伙伴儿们,你们是不是会有疑问:断路器的“壳架电流”和脱扣器的“整定电流”什么关系?二者是否是一回事儿呢?接下来,我们...
- 断路器各种电流之间的关系是什么?作为电气人都需要掌握的知识!
-
提起断路器,想必大部分电气人员都不陌生了,但是如果说到断路器各种电流之间的关系,可能不少电气人员都是云里有雾摸不着头脑,甚至还有一些电气人员是一问三不知的。我们都知道断路器是指能够关合、承载和开断正常...
- ABB高压授权柜UniSafe 提供尽可能多的供配电回路
-
ABB高压开关柜UniSafe以其环保、紧凑的设计而著称,不仅结构紧凑、空间利用率高,还能在有限的占地面积内提供尽可能多的供配电回路,大大节省了资源和土建费用。内部结构部件采用优质材料,如敷铝锌钢板或...
- 如何选择空气开关,详细介绍分析(如何选择空气开关,详细介绍分析方法)
-
空气开关C型与D型的选择需根据负载特性、电流冲击需求和应用场景综合判断,以下是具体分析:一、核心区别空气开关结构简图施耐德空开西门子空开ABB空开ABB塑料外壳断路器施耐德塑料外壳断路器施耐德塑料外壳...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 后端开发必看!Spring Boot3 如何轻松整合 MyBatis 管理 Mapper 接口?
- 每天一个 Python 库:Django全能Web框架,一站式后台开发
- 作为后端开发,你知道MyBatis有哪些隐藏的 “宝藏” 扩展点吗?
- 后端必看!Spring Boot3 跨域难题的五种破局之道
- 这些 Python 后端技术竟成互联网大厂‘敲门砖’,你掌握了几个?
- 后端开发必读,一文带你了解如何配置MyBatis?
- 作为干电气的,低压断路器你真的了解吗?
- 高低压成套电气设备(五)(高低压成套设备技术的标准)
- 深入解析:进线柜、出线柜等六种配电柜的组成和作用
- 自主开发"开关机械特性测试数据智能分析工具"提升检修质量
- 标签列表
-
- MVC框架 (46)
- spring框架 (46)
- 框架图 (58)
- flask框架 (53)
- quartz框架 (51)
- abp框架 (47)
- jpa框架 (47)
- laravel框架 (46)
- springmvc框架 (49)
- 分布式事务框架 (65)
- scrapy框架 (56)
- shiro框架 (61)
- 定时任务框架 (56)
- java日志框架 (61)
- JAVA集合框架 (47)
- mfc框架 (52)
- abb框架断路器 (48)
- grpc框架 (55)
- ppt框架 (48)
- 内联框架 (52)
- cad怎么画框架 (58)
- ps怎么画框架 (47)
- ssm框架实现登录注册 (49)
- oracle字符串长度 (48)
- oracle提交事务 (47)