Spring MVC 解决跨域问题“Access to XMLHttpRequest...”

这个错误提示是由浏览器的同源策略(Same-origin policy)所导致的。要解决Spring MVC中的跨域问题,在项目中添加一个过滤器(Filter)来设置响应头即可。

1.创建一个名为 ​CorsFilter​的类,实现 ​javax.servlet.Filter​接口。

2.在 ​doFilter​方法中,设置响应头中的 ​Access-Control-Allow-Origin​字段为允许跨域请求的来源域名。例如:

import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class CorsFilter implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        HttpServletResponse httpResponse = (HttpServletResponse) response;
        
        // 设置允许跨域的域名
        httpResponse.setHeader("Access-Control-Allow-Origin", "http://localhost:8080");
        
        // 其他设置...
        
        chain.doFilter(request, response);
    }
    
    // 其他方法...
}

 3.在你的web.xml文件中配置该过滤器。找到web.xml文件,并添加如下配置:

<filter>
    <filter-name>CorsFilter</filter-name>
    <filter-class>com.example.CorsFilter</filter-class>  <!-- 替换为你的CorsFilter类所在的完整包路径 -->
</filter>
<filter-mapping>
    <filter-name>CorsFilter</filter-name>
    <url-pattern>/*</url-pattern>  <!-- 可以根据具体需求修改对应的URL模式 -->
</filter-mapping>

 通过上述配置,CorsFilter将会拦截所有请求,并在响应中添加 ​Access-Control-Allow-Origin​ 头部,从而解决跨域问题。

猜你喜欢

转载自blog.csdn.net/weixin_60246228/article/details/132348918