Node js Express 刷新后返回错误 404

希拉

我将我的项目 (NodeJS +Express + ReactJs) 上传到 AWS 上的 Windows 机器。如果我使用特定路径访问网站(例如 demo.co.il),一切都会按预期进行。但是如果我使用类似的东西:demo.co.il/login 它会返回 404 响应:在此处输入图片说明

这是我的 app.js:

var createError = require("http-errors");
var express = require("express");
var path = require("path");
var cookieParser = require("cookie-parser");
var logger = require("morgan");
var cors = require("cors");

var costRouter = require("./routes/Dashboard/Cost/cost");
var programRouter = require("./routes/Dashboard/Program/program");
var projectRouter = require("./routes/Dashboard/Project/project");
var portfolioRouter = require("./routes/Dashboard/Portfolio/portfolio");
var settingRouter = require("./routes/Settings/setting");
var userRouter = require("./routes/User/user");
var filterRouter = require("./routes/Filter/filter");
var topHeaderRouter = require("./routes/TopHeader/topHeader");
var utilsRouter = require("./routes/Utils/utils");
var passwordRouter = require("./routes/Password/password");

var app = express();

// view engine setup
app.set("views", path.join(__dirname, "views"));
app.engine("html", require("ejs").renderFile);
app.set("view engine", "html");

app.use(logger("dev"));
app.use(express.json());
app.use(express.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));
app.use(cors());

app.use("/api/cost", costRouter);
app.use("/api/program", programRouter);
app.use("/api/project", projectRouter);
app.use("/api/portfolio", portfolioRouter);
app.use("/api/settings", settingRouter);
app.use("/api/user", userRouter);
app.use("/api/filter", filterRouter);
app.use("/api/top-header", topHeaderRouter);
app.use("/api/utils", utilsRouter);
app.use("/api/password", passwordRouter);

// catch 404 and forward to error handler
app.use(function (req, res, next) {
  next(createError(404));
});

// error handler
app.use(function (err, req, res, next) {
  // set locals, only providing error in development
  res.locals.message = err.message;
  res.locals.error = req.app.get("env") === "development" ? err : {};

  // render the error page
  res.status(err.status || 500);
  res.render("error");
});

可能是什么问题?

yeya

您需要提供 index.html。

我猜你的反应构建文件在 express 的公共文件夹下,所以要添加这行,调整到反应构建文件的位置:

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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章