如何解决使用代理的Rocket后端React应用提供ECONNREFUSED
我正在尝试使用Rocket制作一个Web应用程序作为后端,并对前端做出反应。但是,当我尝试创建代理时,我会不断收到rayk@pop-os:~/repos/homrs/frontend$ curl http://localhost:3000/api Proxy error: Could not proxy request /api from localhost:3000 to http://localhost:8000 (ECONNREFUSED).
我目前正在尝试将"proxy": "http://localhost:8000"
添加到应用程序中的package.json中,并且我一直尝试按照此处https://create-react-app.dev/docs/proxying-api-requests-in-development/#configuring-the-proxy-manually的建议手动配置代理。
这是我用来测试的后端代码:
#![feature(proc_macro_hygiene,decl_macro)]
#[macro_use] extern crate rocket;
#[get("/")]
fn index() -> &'static str {
"Hello,world!"
}
fn main() {
rocket::ignite().mount("/api",routes![index]).launch();
}
这是我尝试使用的setupProxy.js
const { createProxyMiddleware } = require('http-proxy-middleware');
module.exports = function(app) {
app.use(
'/api',createProxyMiddleware({
target: 'http://localhost:8000',changeOrigin: true,})
);
};
我还尝试使用http://localhost:8000
和http://localhost:8000/
。我还尝试将火箭端口从8000更改为3001,但这也没有用。
编辑:以下是github存储库的链接:https://github.com/GimpFlamingo/homrs
解决方法
这里的人:https://github.com/plouc/mozaik/issues/118遇到了类似的问题。
我能够重现您的问题,发现将address = "127.0.0.1"
添加到Rocket.toml,然后将“ proxy”设置为“ http://127.0.0.1:8080”为我解决了!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。