温馨提示×

springboot配置跨域的方法是什么

小亿
86
2023-11-28 11:57:49
栏目: 编程语言

Spring Boot配置跨域的方法有以下几种:

  1. 使用注解:在Controller类或者方法上使用@CrossOrigin注解来配置跨域访问。可以通过设置origins属性指定允许访问的域名,通过设置methods属性指定支持的HTTP方法,通过设置maxAge属性指定响应的最大生存时间(单位为秒)。

    @RestController
    @RequestMapping("/api")
    @CrossOrigin(origins = "http://example.com", methods = {RequestMethod.GET, RequestMethod.POST}, maxAge = 3600)
    public class MyController {
        // ...
    }
    
  2. 使用WebMvcConfigurer:通过实现WebMvcConfigurer接口,重写addCorsMappings方法来配置全局的跨域访问。可以通过调用addMapping方法指定允许访问的路径,通过调用allowedOrigins方法指定允许访问的域名,通过调用allowedMethods方法指定支持的HTTP方法,通过调用maxAge方法指定响应的最大生存时间(单位为秒)。

    @Configuration
    public class CorsConfig implements WebMvcConfigurer {
        @Override
        public void addCorsMappings(CorsRegistry registry) {
            registry.addMapping("/api/**")
                    .allowedOrigins("http://example.com")
                    .allowedMethods("GET", "POST")
                    .maxAge(3600);
        }
    }
    
  3. 使用Filter:通过自定义一个Filter来处理跨域请求,设置响应的Access-Control-Allow-OriginAccess-Control-Allow-MethodsAccess-Control-Max-Age响应头。

    @Component
    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", "http://example.com");
            response.setHeader("Access-Control-Allow-Methods", "GET, POST");
            response.setHeader("Access-Control-Max-Age", "3600");
            chain.doFilter(req, res);
        }
    }
    

以上是Spring Boot配置跨域的几种方法,根据实际需求选择适合的方法进行配置。

0