提取API不适用于localhost / 127.0.0.1
就像背景一样,我有一个坐在远程EC2
Ubuntu实例上的react应用。同一台服务器还运行一个监听8080端口的Go应用程序(该端口已从“安全性”设置中向所有人开放)。
我正在尝试通过React应用程序使用Fetch API发出请求,如下所示:
var bearer = 'Bearer ...'return fetch('http://localhost:8080" title="localhost:8080">localhost:8080/home', {
headers: new Headers({
'Authorization': bearer
})
})
从Chrome和Firefox的控制台中,我得到:
当我用代替时localhost
,也是如此127.0.0.1
。
但是,使用EC2实例的外部IP是可行的(并且由于“ Authorization”标头而触发了CORS请求,该请求由服务器进行了平稳处理)。
在后一种情况下,我还可以看到服务器记录了OPTIONS和GET的传入请求(在前一种情况下,这两种方法都没有日志)。
我还尝试了从EC2机器到CURL的访问,localhost
并且该请求有效地通过了,这使我认为使用Fetch API根本不会触发该请求。
任何意见,将不胜感激。如果我做错了什么,请指出正确的方向。
回答:
在编写时localhost
,由于js
代码正在浏览器中运行,因此它会调用(本地)浏览器所在的(本地)机器。
您应该为您的API端点创建一个域/子域,并使用它代替localhost,或者继续使用硬编码的IP地址。
您还应该只在允许的后端来源中允许您的前端网站域。例如
您的网站可以是www.example.com
,后端URL可以是www.api.example.com
。您只能允许www.example.com
,origin
因为可以通过进行投放www.api.example.com
。您将需要在后端进行配置。
以上是 提取API不适用于localhost / 127.0.0.1 的全部内容, 来源链接: utcz.com/qa/397540.html