跨域问题的调研记录

本文详细阐述了跨域问题的原理,包括浏览器限制和请求条件,并提供了SpringBoot中@CrossOrigin注解和WebMvcConfigurerAdapter配置跨域的步骤。适合解决前端调用后端接口时遇到的跨域挑战。
摘要由CSDN通过智能技术生成

问题起因

前端要求给项目配置跨域。

疑惑

  1. “跨域”是什么?

  2. 怎么处理“跨域”?

调研记录

“跨域”是什么?

前端调用的后端接口不属于同一个域(域名或端口不同),就会产生跨域问题,也就是说你的应用访问了该应用域名或端口之外的域名或端口。

  1. 为什么会发生跨域问题?

    须同时满足以下三个条件:

    • 浏览器限制

    • 请求地址的域名或端口和当前访问的域名或端口不一样

    • 发送的是XHR(XMLHttpRequest)请求

怎么解决跨域问题

中间件可以配置跨域,但需要修改中间件的配置。Springboot的跨域主要使用@CrossOrigin来实现。给想跨域的方法加上注释即可,也可以加在Contoller头上:

@CrossOrigin
@RestController
@SpringBootApplication
public class SpringBootCorsTestApplication {
    
}

也可以添加SpringWeb的配置类:

@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
​
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowedMethods("POST", "GET", "PUT", "OPTIONS", "DELETE")
                .maxAge(3600)
                .allowCredentials(true);
    }
}

甚至可以添加过滤器来配置:

@Bean
public FilterRegistrationBean corsFilter() {
    UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
    CorsConfiguration config = new CorsConfiguration();
    config.setAllowCredentials(true);   config.addAllowedOrigin("http://localhost:9000");
    config.addAllowedOrigin("null");
    config.addAllowedHeader("*");
    config.addAllowedMethod("*");
    source.registerCorsConfiguration("/**", config); // CORS 配置对所有接口都有效
    FilterRegistrationBean bean = newFilterRegistrationBean(new CorsFilter(source));
    bean.setOrder(0);
    return bean;
}

参考资料

  1. 不要再问我跨域的问题了

  2. 一文搞懂跨域的所有问题,生活从此669~

  3. SpringBoot配置Cors解决跨域请求问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SilverRice

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值