由于前后端分离开发中前端页面与后台在不同的服务器上,必定会出现跨区问题。
解决办法:通过配置bean
import org.springframework.boot.web.servlet.FilterRegistrationBean;
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 CorsConfig {
@Bean
public FilterRegistrationBean corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
CorsConfiguration config = new CorsConfiguration();
//最终的结果是可以 在跨域请求的时候获取同一个 session
config.setAllowCredentials(true);
// * 表示对所有的地址都可以访问
config.addAllowedOrigin("*");
// 跨域的请求头
config.addAllowedHeader("*");
// 跨域的请求方法
config.addAllowedMethod("*");
//配置 可以访问的地址
source.registerCorsConfiguration("/**", config);
FilterRegistrationBean bean = new FilterRegistrationBean(new CorsFilter(source));
bean.setOrder(0);
return bean;
}
}