为什么在express.js中出现错误“app.get不是一个函数”?

3

我无法弄清楚为什么下面代码片段中的upload.js文件会抛出一个错误:app.get不是一个函数。

我有一个index.js文件,我已经配置了所有内容,并通过module.exports = app导出我的应用程序,我还在其中使用了app.set("upload"),但是当我试图在upload.js文件中导入app并使用它时,它会出现错误:error: app.get不是一个函数。

以下是index.js的代码:

const express = require("express");
const app = express();
const multer = require("multer");
const path = require("path");
const uploadRoutes = require("./src/routes/apis/upload.js");


// multer config
const storageDir = path.join(__dirname, "..", "storage");
const storageConfig = multer.diskStorage({
  destination: (req, file, cb) => {
    cb(null, storageDir);
  },
  filename: (req, file, cb) => {
    cb(null, Date.now() + path.extname(file.originalname));
  },
});
const upload = multer({ storage: storageConfig }); // local upload.

//set multer config
app.set("root", __dirname);
app.set("storageDir", storageDir);
app.set("upload", upload);

app.use("/api/upload", uploadRoutes);

const PORT = process.env.PORT || 5002;

if (process.env.NODE_ENV === "development") {
  app.listen(PORT, () => {
    console.log(`Server running in ${process.env.NODE_ENV} on port ${PORT}`);
  });
} else {
  module.exports.handler = serverless(app);
}
module.exports = app;

upload.js文件

const express = require("express");
const router = express.Router();
const app = require("../../../index");

const uploadDir = app.get("storageDir");
const upload = app.get("upload");

router.post(
  "/upload-new-file",
  upload.array("photos"),
  (req, res, next) => {
    const files = req.files;

    return res.status(200).json({
      files,
    });
  }
);

module.exports = router;
1个回答

2

问题在于你有一个循环依赖关系。

应用程序需要上传功能,而上传又需要应用程序。

尝试将应用程序作为参数传递,并重新构建upload.js文件的结构:

const upload = (app) => {
   // do things with app
}

module.exports = upload

然后将其导入应用程序并在此处传递引用(避免在上传中导入应用程序)。

import upload from './path/to/upload'
const app = express();
// ...
upload(app)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接