问题描述
我正在尝试在后端调用 API,但我一直收到连接被拒绝的错误。后端位于部署在 BlueHost 中的 tomcat 服务器内;框架是spring-boot;它的war文件已经部署在webapp文件夹中;并且我已经在 web.xml 中包含了以下过滤器以允许 CORS
<filter>
<filter-name>CorsFilter</filter-name>
<filter-class>org.apache.catalina.filters.CorsFilter</filter-class>
<init-param>
<param-name>cors.allowed.orgins</param-name>
<param-value>*</param-value>
</init-param>
<init-param>
<param-name>cors.allowed.methods</param-name>
<param-value>GET,POST,HEAD,OPTIONS,PUT</param-value>
</init-param>
<init-param>
<param-name>cors.allowed.headers</param-name>
<param-value>Content-Type,X-Requested-With,accept,Origin,Access-Control-Request-Method,Access-Control-Request-Headers</param-value>
</init-param>
<init-param>
<param-name>cors.exposed.headers</param-name>
<param-value>Access-Control-Allow-Origin,Access-Control-Allow-Credentials</param-value>
</init-param>
<init-param>
<param-name>cors.support.credentials</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>CorsFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
由于我相信在 Spring-boot 中已经默认启用了 CORS,所以我没有费心去定义 cors 配置 bean 文件;即使我这样做了,我仍然收到错误消息。我还确保我的客户端请求不包含任何非法标头。但是,它正在执行带有内容类型的飞行前请求。是这样的:
let httpReq = {
method: type,headers: {
"Content-Type": "application/json",Accept: "application/json"
},referrer: window.location.href,// https://web.dev/referrer-best-practices/
referrerPolicy: "strict-origin-when-cross-origin",mode: "cors",credentials: "same-origin",cache: "default",redirect: "error"
};
await fetch("http://localhost:8080" + api,httpReq)
.then(response => {
return response.json();
})
我重新启动了apache和tomcat几次,仍然没有。我也无法从 Tomcat 看到任何有用的日志,而且我还确保该进程仍在使用 netstat。我不知道该怎么做。任何建议将不胜感激。
谢谢
解决方法
该问题源于 httpd.conf 中的包含文件配置错误以及 pom.xml 中的路径配置错误。