微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用代理的Rocket后端React应用提供ECONNREFUSED

如何解决使用代理的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:8000http://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 举报,一经查实,本站将立刻删除。