部署到Heroku后无法访问Express端点的NextJs应用

时间:2019-10-22 21:36:50

标签: express heroku next.js

使用NextJs和Express构建一个在本地运行良好的基本应用程序。但是,一旦部署到Heroku,我将无法访问Express中定义的任何端点。尽管它们在我的本地版本中可用。

您将在下面看到我在其中放置了一条测试路线,该路线会将字符串“ test”呈现到屏幕上。再次可以在本地正常运行,但在heroku上返回404。

gBuffer()

我认为问题实际上可能是我的package.json命令是:

const express = require("express");
const next = require("next");
const bodyParser = require("body-parser");
const { requestWeather } = require("./helpers");

const port = parseInt(process.env.PORT, 10) || 3000;
const dev = process.env.NODE_ENV !== "production";
const app = next({ dev });
const handle = app.getRequestHandler();

app.prepare().then(() => {
  const server = express();

  server.use(bodyParser.urlencoded({ extended: false }));
  server.use(bodyParser.json());

  server.post("/api/weather", async (req, res) => {
    const { lat, long } = req.body;
    const weather = await requestWeather({ lat, long });
    res.send(JSON.stringify({ weather }));
  });

  server.get("/test", (req, res) => {
    res.send('test');
  });

  server.all("*", (req, res) => {
    return handle(req, res);
  });

  server.listen(port, err => {
    console.log(`LOG: HHEEEEE`);
    if (err) throw err;
    console.log(`> Ready on http://localhost:${port}`);
  });
});

实际上它应该引用server.js文件。但是我似乎在这方面没有任何进展。

1 个答案:

答案 0 :(得分:1)

您的应用是通过server.js文件提供的,因此您的启动命令需要如下所示:

"start: "node server.js"