在配置后端跨域的时候 发现 CrossOrigin 一直没有作用,前端一直报跨域错误
网上大多数的解决方法都没有解决,突然看到后端实际上已经接收到了请求,而且被拦截了
在这篇文章中提到了相关信息,是在自定义拦截器返回失败,导致跨域失败
拦截器是链路模式:CrossOrigin也是拦截器并且在自定义拦截器之后。所以在自定义拦截器失败后,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 里 添加了限制,不知道是否会起作用呢?