美文网首页
sentinel流控时web的OPTIONS请求跨域

sentinel流控时web的OPTIONS请求跨域

作者: kingTao_ | 来源:发表于2023-10-07 14:58 被阅读0次

    sentinel流控时,web的OPTIONS请求跨域问题

    添加HandlerInterceptor、WebMvcConfigurer.addCorsMappings层级的跨域配置都不会生效

    原因在于sentinel流控执行的声明周期高于以上层级,需要按如下配置CorsFilter层级的跨域设置

    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.web.cors.CorsConfiguration;
    import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
    import org.springframework.web.filter.CorsFilter;
    
    @Configuration
    public class CustomCORSConfiguration {
        private CorsConfiguration buildConfig(){
            CorsConfiguration corsConfiguration = new CorsConfiguration();
            corsConfiguration.addAllowedHeader("*"); // 允许任何的head头部
            corsConfiguration.addAllowedOrigin("*"); // 允许任何域名使用
            corsConfiguration.addAllowedMethod("*"); // 允许任何的请求方法
            corsConfiguration.setAllowCredentials(true);
            return corsConfiguration;
        }
    
        // 添加CorsFilter拦截器,对任意的请求使用
        @Bean
        public CorsFilter corsFilter() {
            UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
            source.registerCorsConfiguration("/**", buildConfig());
            return new CorsFilter(source);
        }
    }
    

    相关文章

      网友评论

          本文标题:sentinel流控时web的OPTIONS请求跨域

          本文链接:https://www.haomeiwen.com/subject/ercvbdtx.html