SpringBoot+Vue的项目,会出现跨域问题
-
网页会报错
Access to XMLHttpRequest at ‘http://localhost:8085/api/admin/search?currentPage=1&pageSize=10’ from origin ‘http://192.168.43.52:8081’ has been blocked by CORS policy: Response to preflight request doesn’t pass access control check: It does not have HTTP ok status.
-
后台会报错
Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed: com.jiang.exception.CustomException] with root cause
解决方法
在后台随便一个包里新建CorsConfig.java类,内容如下
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 CorsFilter corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
CorsConfiguration corsConfiguration = new CorsConfiguration();
corsConfiguration.addAllowedOrigin("*"); // 1 设置访问源地址
corsConfiguration.addAllowedHeader("*"); // 2 设置访问源请求头
corsConfiguration.addAllowedMethod("*"); // 3 设置访问源请求方法
source.registerCorsConfiguration("/**", corsConfiguration); // 4 对接口配置跨域设置
return new CorsFilter(source);
}
}
如图所示: