SpringBoot 如何使用 CORS 进行跨域资源共享

简介: SpringBoot 如何使用 CORS 进行跨域资源共享

SpringBoot 如何使用 CORS 进行跨域资源共享


在 Web 开发中,跨域资源共享(CORS)是常见的问题之一。CORS 是一种安全机制,用于限制跨域请求对目标服务器的访问。在本文中,我们将介绍如何在 Spring Boot 中使用 CORS 进行跨域资源共享。


7da84cacabf7f2099aca3706c150048a_404fc4beaf8a4a5bbe029b98fb7c7dab.png


什么是 CORS?


CORS 是一种 Web 应用程序的安全机制,用于限制跨域请求对目标服务器的访问。如果一个 Web 应用程序从一个源请求资源,而该资源位于另一个源,那么跨域就发生了。CORS 机制允许服务器在响应中设置一组跨域访问控制头来告诉浏览器哪些跨域请求是允许的。


如何配置 CORS?


在 Spring Boot 中,可以通过配置 WebMvcConfigurerAdapter 来启用 CORS。以下是一个示例:


@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/api/**")
            .allowedOrigins("http://localhost:8080")
            .allowedMethods("GET", "POST")
            .allowedHeaders("header1", "header2", "header3")
            .exposedHeaders("header1", "header2")
            .allowCredentials(false).maxAge(3600);
    }
}

在上面的示例中,我们使用 @Configuration 注解创建了一个名为 WebMvcConfig 的类,并继承了 WebMvcConfigurerAdapter 类。我们使用 addCorsMappings() 方法配置了 CORS,指定了允许跨域请求的 URL、HTTP 方法、请求头、响应头以及其他选项。


CORS 配置选项


在上面的示例中,我们使用了以下选项:


  • allowedOrigins - 允许跨域请求的 URL。
  • allowedMethods - 允许跨域请求的 HTTP 方法。
  • allowedHeaders - 允许跨域请求的请求头。
  • exposedHeaders - 允许被客户端访问的响应头。
  • allowCredentials - 是否允许发送 cookie 等凭据信息。
  • maxAge - 响应的最大缓存时间(以秒为单位)。


全局 CORS 配置


如果您希望在整个应用程序中启用 CORS,可以使用以下配置:


@Configuration
@EnableWebMvc
public class WebConfig implements WebMvcConfigurer {
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
            .allowedOrigins("*")
            .allowedMethods("*")
            .allowedHeaders("*")
            .exposedHeaders("header1", "header2")
            .allowCredentials(false).maxAge(3600);
    }
}

在上面的示例中,我们使用 @Configuration 和 @EnableWebMvc 注解创建了一个名为 WebConfig 的类,并实现了 WebMvcConfigurer 接口。我们使用 addCorsMappings() 方法配置了全局 CORS,指定了允许跨域请求的 URL、HTTP 方法、请求头、响应头以及其他选项。


使用 Filter 配置 CORS


另一种配置 CORS 的方法是使用 Filter。以下是一个示例:


@Component
@Order(Ordered.HIGHEST_PRECEDENCE)
public class CorsFilter implements Filter {
    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain)
            throws IOException, ServletException {
        HttpServletResponse response = (HttpServletResponse) res;
        HttpServletRequest request = (HttpServletRequest) req;
        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");
        if ("OPTIONS".equalsIgnoreCase(request.getMethod())) {
            response.setStatus(HttpServletResponse.SC_OK);
        } else {
            chain.doFilter(req, res);
        }
    }
}

在上面的示例中,我们使用 @Component 注解创建了一个名为 CorsFilter 的类,并实现了 Filter 接口。我们使用 doFilter() 方法配置了 CORS,指定了允许跨域请求的 URL、HTTP 方法、请求头、响应头以及其他选项,并在 OPTIONS 方法中返回 HTTP OK 状态码。


遇到的问题及解决方案


在实际使用中,可能会遇到一些问题。以下是一些常见的问题及解决方案:


1. 配置 CORS 无效


如果您的配置不起作用,可以尝试配置 @CrossOrigin 注解。例如:


@RestController
@RequestMapping("/api")
@CrossOrigin(origins = "http://localhost:8080")
public class ApiController {
    // ...
}

在上面的示例中,我们使用 @CrossOrigin 注解配置了允许跨域请求的 URL。


2. 预检请求失败


当浏览器尝试进行跨域请求时,它将发送一个预检请求,以确定服务器是否允许跨域请求。如果预检请求失败,则跨域请求将被阻止。以下是一些可能导致预检请求失败的原因:


  • 请求头未被正确配置。如果您使用了自定义请求头,需要将它们包含在 allowedHeaders 中。
  • 请求方法未被正确配置。如果您使用了非 GET 或 POST 方法,需要将它们包含在 allowedMethods 中。
  • 响应头未被正确配置。如果您使用了自定义响应头,需要将它们包含在 exposedHeaders 中。


3. 跨域请求失败


当浏览器发送跨域请求时,它将检查服务器是否允许该跨域请求。如果服务器不允许该请求,浏览器将阻止该请求。以下是一些可能导致跨域请求失败的原因:


  • 允许跨域请求的 URL 未被正确配置。请确保将需要允许跨域请求的 URL 包含在 allowedOrigins 中。
  • 允许跨域请求的 HTTP 方法未被正确配置。请确保将需要允许跨域请求的 HTTP 方法包含在 allowedMethods 中。


结论


在本文中,我们介绍了如何在 Spring Boot 中使用 CORS 进行跨域资源共享。我们介绍了配置 CORS 的两种方法:使用 WebMvcConfigurerAdapter 和 Filter。我们还讨论了一些可能遇到的问题及其解决方案。我们希望本文能够帮助您解决在 Spring Boot 中使用 CORS 的问题。


相关文章
|
18天前
|
存储 安全 前端开发
第五章 跨域资源共享(CORS):现代Web开发中的关键机制
第五章 跨域资源共享(CORS):现代Web开发中的关键机制
|
18天前
|
移动开发 JSON 前端开发
跨域资源共享(CORS):详解跨域请求的限制与解决方法
跨域资源共享(CORS):详解跨域请求的限制与解决方法
|
6天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp的资源共享平台的详细设计和实现(源码+lw+部署文档+讲解等)
基于SpringBoot+Vue+uniapp的资源共享平台的详细设计和实现(源码+lw+部署文档+讲解等)
1天搞定SpringBoot+Vue全栈开发 (9)JWT跨域认证
1天搞定SpringBoot+Vue全栈开发 (9)JWT跨域认证
|
10天前
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp微信小程序的资源共享平台的共享与开发的详细设计和实现
基于SpringBoot+Vue+uniapp微信小程序的资源共享平台的共享与开发的详细设计和实现
|
14天前
|
JSON 安全 前端开发
跨域详解及Spring Boot 3中的跨域解决方案
本文介绍了Web开发中的跨域问题,包括概念、原因、影响以及在Spring Boot 3中的解决方案。跨域是由浏览器的同源策略限制引起的,阻碍了不同源之间的数据传输。解决方法包括CORS、JSONP和代理服务器。在Spring Boot 3中,可以通过配置CorsFilter来允许跨域请求,实现前后端分离项目的正常运行。
68 3
 跨域详解及Spring Boot 3中的跨域解决方案
|
18天前
|
前端开发 安全 JavaScript
跨域资源共享(CORS)
跨域资源共享(CORS)
19 0
|
19天前
|
Java Spring
快速解决Spring Boot跨域困扰:使用CORS实现无缝跨域支持
这是一个简单的配置示例,用于在Spring Boot应用程序中实现CORS支持。根据你的项目需求,你可能需要更详细的配置来限制允许的来源、方法和标头。
32 3
|
19天前
|
前端开发 JavaScript Java
SpringBoot解决跨域访问的问题
本文介绍了跨域访问的概念及其解决方案。同源策略规定浏览器限制不符合协议、Host和端口的请求,导致跨域访问被禁止。为解决此问题,文中提出了三种策略:1) 前端利用HTML标签的特性(如script、iframe)和JSONP、postMessage规避同源策略;2) 通过代理,如nginx或nodejs中间件,使得所有请求看似来自同一源;3) CORS(跨域资源共享),通过设置HTTP响应头允许特定跨域请求。在SpringBoot中,实现CORS有四种方式,包括使用CorsFilter、重写WebMvcConfigurer、CrossOrigin注解以及直接设置响应头。
|
19天前
|
缓存 前端开发 安全
Python web框架fastapi中间件的使用,CORS跨域详解
Python web框架fastapi中间件的使用,CORS跨域详解