0

0

Spring Boot实现和解决跨域问题的技巧

王林

王林

发布时间:2023-06-22 21:38:28

|

1856人浏览过

|

来源于php中文网

原创

随着前后端分离的普及,前端与后端之间的跨域问题也逐渐成为web开发人员面临的一个问题。跨域问题涉及到浏览器的同源策略,即在默认情况下,浏览器只允许页面向同源服务器发起请求,而不能向其他域名的服务器发起请求。本文将介绍如何使用spring boot框架实现和解决跨域问题。

  1. 什么是跨域问题?

跨域问题是指在浏览器中,当一个Web应用在A域名下运行,向B域名下的Web应用程序发送请求时,浏览器会阻止此请求,因为这不符合浏览器同源策略的规定。同源策略指的是只有在相同协议、域名、端口号相同的情况下,浏览器才允许页面向服务器发起请求。

  1. Spring Boot支持的解决跨域方法

Spring Boot提供了多种解决跨域问题的方法,下面介绍几种比较常用的方法。

2.1 使用注解@CrossOrigin

在Spring Boot中,可以使用注解@CrossOrigin来实现跨域请求。@CrossOrigin注解可用于类或方法级别,并且可以指定CORS的一些选项,例如允许跨域访问的域名、允许的请求方式等。下面是一个使用@CrossOrigin注解的示例代码:

@RestController
@RequestMapping("/api")
@CrossOrigin(origins = "http://localhost:8080", maxAge = 3600)
public class ApiController {

    @GetMapping("/hello")
    public String hello() {
        return "Hello World!";
    }
}

以上代码中,使用了@CrossOrigin注解并指定了跨域域名为http://localhost:8080,同时设置了最长缓存时间为1小时。这样,在前端Ajax请求时,就可以跨域访问http://localhost:8080了。需要注意的是,@CrossOrigin注解应该添加在控制器类上或方法上,而不是加到@RequestBody参数上。

2.2 配置WebMvcConfigurer

另一种解决跨域问题的方法是通过实现WebMvcConfigurer接口,并覆盖addCorsMappings方法,使用CorsRegistry配置允许跨域访问的域名。下面是示例代码:

Delphi 7应用编程150例 全书内容 CHM版
Delphi 7应用编程150例 全书内容 CHM版

Delphi 7应用编程150例 CHM全书内容下载,全书主要通过150个实例,全面、深入地介绍了用Delphi 7开发应用程序的常用方法和技巧,主要讲解了用Delphi 7进行界面效果处理、图像处理、图形与多媒体开发、系统功能控制、文件处理、网络与数据库开发,以及组件应用等内容。这些实例简单实用、典型性强、功能突出,很多实例使用的技术稍加扩展可以解决同类问题。使用本书最好的方法是通过学习掌握实例中的技术或技巧,然后使用这些技术尝试实现更复杂的功能并应用到更多方面。本书主要针对具有一定Delphi基础知识

下载
@Configuration
public class CorsConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
                .allowedOrigins("http://localhost:8080")
                .allowedMethods("GET", "POST")
                .maxAge(3600);
    }
}

以上代码中,CorsConfig类实现了WebMvcConfigurer接口,并覆盖了addCorsMappings方法,只允许http://localhost:8080域名下的GET、POST请求访问。包含"/api"的路径都会受到CORS的限制,而其他路径将不受任何限制。

2.3 配置Filter

使用过滤器也是一种解决跨域问题的方法。下面是一个使用过滤器的示例:

@Component
public class CorsFilter implements Filter {

    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
            throws ServletException, IOException {
        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "http://localhost:8080");
        response.setHeader("Access-Control-Allow-Methods", "GET, POST");
        response.setHeader("Access-Control-Max-Age", "3600");
        chain.doFilter(req, res);
    }
}

以上代码中,CorsFilter类实现了Filter接口,并添加了Access-Control-Allow-Origin、Access-Control-Allow-Methods、Access-Control-Max-Age等请求头信息,允许http://localhost:8080域名下的GET、POST请求访问。

  1. 总结

本文介绍了使用Spring Boot框架实现和解决跨域问题的三种常用方法。使用注解@CrossOrigin、配置WebMvcConfigurer以及使用过滤器都可以实现CORS的限制和控制。在实际开发中,应根据自己的需求选择最适合的方法来解决跨域问题。

相关专题

更多
微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

2

2026.01.18

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

74

2026.01.16

全民K歌得高分教程大全
全民K歌得高分教程大全

本专题整合了全民K歌得高分技巧汇总,阅读专题下面的文章了解更多详细内容。

133

2026.01.16

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

54

2026.01.16

java数据库连接教程大全
java数据库连接教程大全

本专题整合了java数据库连接相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.15

Java音频处理教程汇总
Java音频处理教程汇总

本专题整合了java音频处理教程大全,阅读专题下面的文章了解更多详细内容。

19

2026.01.15

windows查看wifi密码教程大全
windows查看wifi密码教程大全

本专题整合了windows查看wifi密码教程大全,阅读专题下面的文章了解更多详细内容。

106

2026.01.15

浏览器缓存清理方法汇总
浏览器缓存清理方法汇总

本专题整合了浏览器缓存清理教程汇总,阅读专题下面的文章了解更多详细内容。

44

2026.01.15

ps图片相关教程汇总
ps图片相关教程汇总

本专题整合了ps图片设置相关教程合集,阅读专题下面的文章了解更多详细内容。

11

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.8万人学习

Rust 教程
Rust 教程

共28课时 | 4.5万人学习

Vue 教程
Vue 教程

共42课时 | 6.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号