Spring @CrossOrigin不起作用

在Spring应用中,由于自定义拦截器和CrossOrigin拦截器顺序导致跨域设置失效。通过添加Filter并设置全局跨域配置,解决了跨域问题。尽管AllowedOriginPattern设为*,但Controller中的限制可能仍会生效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在配置后端跨域的时候 发现 CrossOrigin 一直没有作用,前端一直报跨域错误

在这里插入图片描述网上大多数的解决方法都没有解决,突然看到后端实际上已经接收到了请求,而且被拦截了

在这里插入图片描述

在这篇文章中提到了相关信息,是在自定义拦截器返回失败,导致跨域失败
拦截器是链路模式:CrossOrigin也是拦截器并且在自定义拦截器之后。所以在自定义拦截器失败后,CrossOrigin没有进行处理导致没有进行跨域就返回结果

Spring @CrossOrigin 注解失效,导致跨域问题

采取解决方案:添加filter ,因为Filter优先于拦截器执行,所以拦截器失败不会影响跨域处理。

@Configuration
public class GlobalCorsConfig {
    @Bean
    public CorsFilter corsFilter() {
        CorsConfiguration config = new CorsConfiguration();
        config.addAllowedOriginPattern("*");
        config.setAllowCredentials(true);
        config.addAllowedMethod("*");
        config.addAllowedHeader("*");
            UrlBasedCorsConfigurationSource configSource = new UrlBasedCorsConfigurationSource();
        configSource.registerCorsConfiguration("/**", config);
        return new CorsFilter(configSource);
    }
}

添加后解决!

不过这个有个疑问:AllowedOriginPattern是 * 会接受所有的跨域

但是Controller 里 添加了限制,不知道是否会起作用呢?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值