springboot解决跨域问题

在项目的启动文件Application的同级下创建AppWebMvcConfigurer


使之继承 WebMvcConfigurerAdapter

springboot解决跨域问题

@Configuration
public class AppWebMvcConfigurer extends  WebMvcConfigurerAdapter{
@Bean
    public FilterRegistrationBean corsFilterRegistration() {
        FilterRegistrationBean registration = new FilterRegistrationBean();
        registration.setFilter(corsFilter());
        registration.addUrlPatterns("/*");
        registration.setName("corsFilter");
        registration.setOrder(Ordered.HIGHEST_PRECEDENCE);
        return registration;
    }
@Bean
    public Filter corsFilter() {
        return new CorsFilter();
    }
}


之后添加CorsFilter 类,实现过滤规则 如Ip 端口之类的

springboot解决跨域问题

ublic class CorsFilter implements Filter {


public void init(FilterConfig filterConfig) throws ServletException {


}


public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
String method = ((HttpServletRequest) request).getMethod();
HttpServletResponse res = (HttpServletResponse) response;


String host = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort();
res.addHeader("host", host);
res.addHeader("Access-Control-Expose-Headers","Roleplay-Error-Code");
res.addHeader("Access-Control-Allow-Origin", "*");
res.addHeader("Access-Control-Allow-Methods", "GET,POST,PUT,DELETE,OPTIONS");
res.addHeader("Access-Control-Allow-Credentials", "true");
res.addHeader("Access-Control-Allow-Headers",
 "Origin, Content-Type, Accept, Authorization, x-requested-with, cache-control, Access-Control-Allow-Origin, Access-Control-Allow-Credentials, uuid");


if (method.equals("OPTIONS")) {
res.setStatus(HttpServletResponse.SC_OK);
}else {
chain.doFilter(request, response);
}


}


public void destroy() {


}
}



通过项目web访问后台获得数据

springboot解决跨域问题

springboot跨域即可完成