与猫鼬模式关联的Multer GridFS存储文件上传

时间:2019-06-27 02:03:01

标签: mongoose multer gridfs gridfs-stream multer-gridfs-storage

我可以使用multer-gridfs-storage将文件上传到MongoDB,但是在将文件与“客户”模式关联时遇到了麻烦。基本上,每个客户应具有三种类型的文件:网络,电子邮件和密码文件。 每个文件都是一个.txt。我的最终目标是为每个客户提供一个显示页面,并能够通过:id找到客户,然后填充客户的三个文件。

const mongoose = require("mongoose");
const Schema = mongoose.Schema;

const customerSchema = new Schema({
    name: {
        type: String
          },
    address: {
        street: String,
        city: String,
        state: String,
        zip: String,
    },
    fileID:
        {
            type: Schema.Types.ObjectId,

        }

}, { timestamps: true });


module.exports = mongoose.model("Customer", customerSchema);



// Create mongo connection
const conn = mongoose.createConnection(process.env.MONGO_DB_URL);

// Init gfs
let gfs;

conn.once('open', () => {
  // Init stream
  gfs = Grid(conn.db, mongoose.mongo);
  gfs.collection('customers');
});

// Create storage engine
const storage = new GridFsStorage({
  url: process.env.MONGO_DB_URL,
  file: (req, file) => {
        return {
        filename: file.originalname,
        bucketName: 'customers'
        };


  }
});
const upload = multer({ storage });



post route to upload files

router.post('/upload', upload.single('file'), (req, res) => {
    res.json({ file: req.file });
  });

1 个答案:

答案 0 :(得分:0)

您的客户模型中的三种文件类型都有三个字段。使用gridfs-storage将文件保存到其他集合中,然后将这些已上传文件的ID存储到模型中的相应字段中。这样,您可以保留不同类型的文件的不同集合。