【问题标题】:React / Express - Error: ENOENT: no such file or directory, stat '/app/build/index.html'React / Express - 错误:ENOENT:没有这样的文件或目录,stat '/app/build/index.html'
【发布时间】:2021-04-26 05:11:31
【问题描述】:

请参阅下面的修改 请让我摆脱这里的痛苦。我花了几个小时浏览文档并尝试在此站点上找到的不同方法。当 heroku 从 github 提取代码后尝试构建时出现此错误:

错误:ENOENT:没有这样的文件或目录,stat '/app/build/index.html'

我的客户端代码位于根目录,我的快速服务器代码位于 /server。
节点正在从根 package.json 启动(例如 node server/index.js)。
如果我 bash 进入 heroku,我可以看到 /build/index.html 文件。

app.use(express.static(path.resolve(__dirname, '../build')));
app.get('*', (req, res) => {
  res.sendFile(path.resolve('build/index.html'));
});

编辑

其他有趣的东西。如果我像这样设置路径,我可以在 localhost:5000 上的 /build 文件夹中浏览我的图像(与根目录相同的路径),但我仍然在 prod 中遇到相同的错误。

app.use(express.static(path.join(__dirname, '/../build')));

编辑 2:
事实证明,我需要添加对“public”的静态引用。啊!
我现在可以在构建目录中看到索引和其他任何内容。
但是,没有对构建期间创建的静态/js 文件的引用,因此该页面是空的。我可以在 bash 提示符下在服务器上看到它们。

app.use(express.static(path.join(__dirname, '..', 'build')));
app.use(express.static('public'));

app.use((req, res, next) => {
  res.sendFile(path.join(__dirname, '..', 'build', 'index.html'));
});

【问题讨论】:

  • 这是否与stackoverflow.com/a/39535945/7306148中的问题类似
  • 感谢您的回复!不,在那篇文章中,问题是开发人员正在进行本地构建和命令行推送,并且由于 .gitignore 的问题而丢失了一个文件夹。我正在让 heroku 进行构建。
  • ENOENT 听起来您的路径不正确。为Heroku 上的应用程序提供服务的目录是什么?如果您执行path.join(__dirname, "./build/index.html") 之类的操作怎么办?
  • @goto1 非常感谢您的回复。该应用程序是从 app/build 提供的(与“服务器”不同,客户端代码不是一个级别),并且此代码位于 app/server.xml 中。 __dirname 确认运行时的当前目录是 app/server。 res.sendFile(path.join(__dirname, './build/index.html'));我试过这个并得到这个错误:错误:ENOENT:没有这样的文件或目录,stat'/app/server/build/index.html'。
  • @AdamCodes716 如果我理解正确,您的客户端代码在app/build 下,而您的服务器端代码在app/server 下,所以您应该上一个目录,如下所示:@ 987654331@

标签: node.js reactjs express heroku


【解决方案1】:

我从来没有发现问题,所以我缩小了规模并再次尝试。最终,我认为您甚至不需要引用 index.html 文件。在根级别我有 server.js。在该文件中,我只是在路由文件之后引用客户端/构建,这作为路由中未找到的任何内容的默认值:

app.use(express.static("client/build"));

【讨论】:

    【解决方案2】:

    我希望这能帮助其他人解决这个问题。我本周遇到了这个错误,我解决了它。就我而言,它与 client/build/index.html 路径无关。我敢打赌,你的情况也是如此。

    请大家多多包涵,先过一下这几点,看看问题出在哪里:

    问题在于,当您创建 react 应用程序时,它会以某种方式自动运行 git init 命令。您最终会得到 2 个 git 文件夹:一个用于 Express 后端,另一个用于您的 react 客户端文件夹。 结果是,当您提交更改时,客户端文件夹中的更改不会被推送到 heroku。

    要说服自己确实是这种情况,请在项目根目录下的终端中运行以下命令:

    a) heroku run bash
    
    b) cd into the client folder
    
    c) ls client
    

    如果在这个阶段您看不到客户端文件夹的内容,那么这就是导致问题的原因。

    现在是补救措施:

    转到您的终端并运行这些命令(来源:Content of create-react-app is not pushed in github

    mv client subfolder_tmp
    git submodule deinit client
    git rm --cached client
    mv subfolder_tmp client
    git add client
    

    现在在您的客户端文件夹中进行更改,然后将它们推送到 heroku (git add . , git commit -m "", git push heroku master)

    如果这有帮助,请告诉我,我知道我通过这种方式解决了我的问题。

    【讨论】:

      猜你喜欢
      • 2019-08-22
      • 2017-01-24
      • 2021-09-22
      • 2021-04-04
      • 2020-06-03
      • 1970-01-01
      • 2019-05-08
      • 1970-01-01
      • 2020-12-05
      相关资源
      最近更新 更多