package com.imooc.config;
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 {
public CorsConfig() {
}
@Bean
public CorsFilter corsFilter() {
// 1. 添加cors配置信息
CorsConfiguration config = new CorsConfiguration();
// 设置是否发送cookie信息
config.setAllowCredentials(true);
config.addAllowedOrigin("http://localhost:8080");
config.addAllowedOrigin("http://192.168.3.16"); // 前端地址80端口
config.addAllowedOrigin("http://192.168.3.16:9999"); // 前端地址9999端口
// 设置允许请求的方式
config.addAllowedMethod("*");
// 设置允许的header
config.addAllowedHeader("*");
// 2. 为url添加映射路径
UrlBasedCorsConfigurationSource corsSource = new UrlBasedCorsConfigurationSource();
corsSource.registerCorsConfiguration("/**", config);
// 3. 返回重新定义好的corsSource
return new CorsFilter(corsSource);
}
}
说明:addAllowedOrigin填充一般是:域名:端口,但这里我使用的虚拟机,所以想让192.168.3.16这个访问请求进行跨域,前端项目部署在192.168.3.16 节点的tomcat上,addAllowedOrigin只能是使用:ip:端口,如:http://192.168.3.16:9999 , 所以只能是把前端项目放到tomcat的ROOT目录下,如果使用:http://192.168.3.16:9999/foodie-shop 这样的地址,无法解决跨域问题。被这个坑了2小时了,特意记录下