【发布时间】:2021-04-26 06:38:53
【问题描述】:
我正在尝试在后端调用 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 文件;即使我这样做了,我仍然收到错误。我还确保我的客户请求不包含任何非法标头。但是,它使用 Content Type 执行飞行前请求。如下:
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。我不知道该怎么做。任何建议将不胜感激。
谢谢
【问题讨论】:
标签: spring-boot tomcat bluehost