Spring Boot 设置允许跨域的两种配置方式

Spring Boot 设置允许跨域的两种配置方式

1.配置MvcConfigurer

  • Spring Boot 1.5.x
//springboot 1.5方式
@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
 
  @Override
  public void addCorsMappings(CorsRegistry registry) {
    registry.addMapping("/**")
    	.allowedHeaders("*")
      	.allowedMethods("*")
      	.allowedOrigins("*")
      	.allowCredentials(true);
  }
}
  • Spring Boot 2.0.x
//springboot 2.0以上的方式
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
 
    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
        	.allowedHeaders("*")
            .allowedMethods("*")
            .allowedOrigins("*")
            .allowCredentials(true);
    }
}

2.使用过滤器的方式

@Configuration
public class WebConfig {

	@Bean
    public CorsFilter corsFilter() {
		final UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
        final CorsConfiguration config = new CorsConfiguration();
        config.setAllowCredentials(true); // 允许cookies跨域
        config.addAllowedOrigin("*");// #允许向该服务器提交请求的URI,*表示全部允许,在SpringMVC中,如果设成*,会自动转成当前请求头中的Origin
        config.addAllowedHeader("*");// #允许访问的头信息,*表示全部
        config.setMaxAge(18000L);// 预检请求的缓存时间(秒),即在这个时间段里,对于相同的跨域请求不会再预检了
        config.addAllowedMethod("*");// 允许提交请求的方法,*表示全部允许
        source.registerCorsConfiguration("/**", config);
        return new CorsFilter(source);
    }
}

Tips: 如果使用了拦截器 应该使用第二种方式在过滤其中配置允许跨域,可能会出现配置上允许跨域不起作用

上一篇:国内npm镜像站更换新域名了


下一篇:npm镜像源如何设置