前端服务请求跨域被拦截,Java后端Springboot服务解决办法

跨域问题

跨域前端遇到的问题:

Access to XMLHttpRequest at 'http://www.xxx.xxxx/api/x/d/xc' from origin 'http://127.0.0.1:3000' has been blocked by cors policy: No 'Access-Contorl-Allow-Origin' header is present on the requested resource.

其实我们看这个错误,很明显可以理解请求被拦截。为什么被拦截呢,其实后端默认返回的response header中没有'Access-Contorl-Allow-Origin'。

详细分析跨域

什么是跨域:当一个请求 url 的协议、域名、端口三者之间任意一个与当前页面 url 不同即为跨域,出现跨域错误的原因是:发起请求的服务(前端)所在域跟服务所在的域,不在同一个域中。

CORS 机制允许 Web 应用服务器进行跨源访问控制,从而使跨源数据传输得以安全进行。现代浏览器支持在 API 容器中(例如 XMLHttpRequest 或 Fetch)使用 CORS,以降低跨源 HTTP 请求所带来的风险。

Springboot配置跨域过滤器解决跨域问题

主要就是在后端返回的时候,自动给response加几个header,也可以使用拦截器或者其他方式处理。

java 复制代码
// 创建一个filter
@Component
public class CORSFilter implements Filter {
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) res;

        response.setHeader("Access-control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Credentials", "true");
        response.setHeader("Access-Control-Allow-Headers", "*");
        response.addHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE, PUT");
        if ("OPTIONS".equals(request.getMethod())) {
            response.setStatus(HttpStatus.NO_CONTENT.value());
            return;
        } else {
            chain.doFilter(request, response);
        }
    }

    public void init(FilterConfig filterConfig) {}

    public void destroy() {}
}

// 过滤器配置
@Configuration
public class AuthConfiguration {
    @Bean
    public FilterRegistrationBean<CORSFilter> corsFilterRegistrationBean(CORSFilter corsFilter){
        FilterRegistrationBean<CORSFilter> registrationBean = new FilterRegistrationBean<>();
        registrationBean.setFilter(corsFilter);
        registrationBean.setName("CORSFilter");
        registrationBean.setOrder(Ordered.HIGHEST_PRECEDENCE);
        registrationBean.addUrlPatterns("/*");
        registrationBean.setOrder(0);
        return registrationBean;
    }
}
相关推荐
凡人叶枫1 分钟前
Effective C++ 条款35:考虑 virtual 函数以外的其他选择
java·c++·spring
lvchaoq1 分钟前
从原理层面解释前端大数据量性能优化系列——分片加载
前端
garmin Chen9 分钟前
从 Transformer 到 Agent:大模型技术全景解析
java·人工智能·python·深度学习·transformer
愚公移码14 分钟前
蓝凌EKP18产品:流程引擎技术篇之流程核心概念模型
java·人工智能·流程引擎·蓝凌
Full Stack Developme21 分钟前
Apache Tika 教程
java·开发语言·python·apache
鹅城剑仙25 分钟前
Spring Boot 微服务架构设计与最佳实践
spring boot·后端·微服务
杨先生哦35 分钟前
2026 热端攻防:AI 驱动 Web 前端安全全景透析
前端·笔记·安全·web安全
鹅城剑仙35 分钟前
Java线程池完全指南
java
李白的天不白38 分钟前
SmartAdmin(基于 Spring Boot 框架)中配置跨域请求 VUE3 设置请求头
java·前端
橙子进阶之路39 分钟前
Java线程(CompletableFuture)
java·开发语言