这个错误提示是由浏览器的同源策略(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
头部,从而解决跨域问题。