node.js - 使用 Node.js 提供静态文件时出现问题,有时找到文件,有时找不到文件,如何解决?
问题描述
create-react-app
我用 Node.js 作为后端做了一个 React 项目。我使用 Node.js 提供静态文件。
我试图弄清楚几个小时。当我在 docker 中运行并将应用程序推送到 Heroku 时,有时会出现此错误:错误:ENOENT:没有这样的文件或目录,stat '/usr/src/app/server/build/index.html'
那很奇怪 ?如果我点击周围,一切正常。突然它不起作用,它告诉我它找不到index.html
?
如果我再次进入该页面并再次单击,一切正常。为什么会这样?
我在 node.js 文件中提供静态文件的代码server.js
:
// Serve static files if in production or running in docker
if ( process.env.NODE_ENV === "production" || process.env.NODE_ENV === "docker" ) {
// Set static folder
app.use("/", express.static("build"));
app.get("*", (req, res) => {
res.sendFile(path.resolve(__dirname, "build", "index.html"));
});
}
我的文件夹结构:
还有我的反应路由器:
import Homepage from "./pages/Homepage";
import Dashboard from "./pages/Dashboard";
import Leaderboard from "./pages/Leaderboard";
import Signup from "./pages/Signup";
import Login from "./pages/Login";
import About from "./pages/About";
import Quiz from "./pages/Quiz";
import Locked from "./containers/Locked";
import WebSocketService from "./services/WebSocketService";
// Add the redux.dispatch function to WebSocketService
WebSocketService.setDispatch(store.dispatch);
ReactDOM.render(
<Provider store={store}>
<Router>
<Switch>
<Route exact path="/" component={Homepage} />
<Route exact path="/signup" component={Signup} />
<Route exact path="/login" component={Login} />
<Route exact path="/about" component={About} />
{/* Locked */}
<Locked>
<Route exact path="/leaderboard" component={Leaderboard} />
<Route exact path="/dashboard" component={Dashboard} />
<Route exact path="/play/:quizId" component={Quiz} />
</Locked>
{/* 404 */}
<Redirect to="/" />
</Switch>
</Router>
</Provider>,
document.getElementById("root")
);
在开发模式下一切正常,但在生产中我遇到了这些问题。当我在开发模式下刷新页面时,我仍然在页面上。如果我在生产模式下刷新,我也会得到同样的错误:错误:ENOENT:没有这样的文件或目录,stat '/usr/src/app/server/build/index.html'
我可以做任何调整来避免它吗?感谢您的帮助!
解决方案
我解决了这个问题。
用于提供静态文件的新代码。
// Serve static files if in production or running in docker
if ( process.env.NODE_ENV === "production" || process.env.NODE_ENV === "docker" ) {
// Set static folder
app.use(express.static(path.join(__dirname, '../build')));
app.get('/*', (req, res) => {
res.sendFile(path.join(__dirname, '../build', 'index.html'));
});
}
推荐阅读
- python - 从返回的数据中删除索引
- java - 如何从 Java 执行 EXECUTE IMMEDIATE?
- google-cloud-platform - 如何在“gcloud builds”中使用“gcloud deployment-manager deployments”在 GCP 上有完整的 CI/CD 管道?
- html - 如何避免滚动条堆叠
- shortest-path - Dijkstra-添加新的verticle
- reactjs - 如何使用 componentWillUnmount 停止循环动画?
- c++ - 如何将动态和静态二维数组作为空指针传递?
- excel - 将用户输入与两列进行比较,并从第三个预定义列返回值
- jpa - JPA:如何通过妥协的 where 子句获得结果
- sql - 检查地图上的点(经纬度)是否在多边形内