Стратегия загрузки изображений в mongoDB Atlas с помощью multer? - PullRequest
0 голосов
/ 02 марта 2020

Моя цель - иметь возможность загружать изображения в mongoDB Atlas с помощью Multer. В настоящее время я настроил пример с генератором express со следующими соответствующими файлами:

app. js:

// ...
var app = express();

//Set up mongoose connection
var mongoose = require('mongoose');
var mongoDB = 'mongodb+srv://username:password@cluster0-wczgu.mongodb.net/test?retryWrites=true&w=majority';
mongoose.connect(mongoDB, { useNewUrlParser: true });
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'MongoDB connection error:'));
// ...

index. js:

var express = require('express');
var router = express.Router();
var multer = require("multer");
var fs = require("fs");
var upload = multer({ dest: 'uploads/' })
var Image = require('../models/image');

// GET for image form
router.get("/image/create", function(req, res, next) {
    res.render("create_image", {title: "Create Image"});
});

// Uploading image to mongoDB Atlas
router.post("/image/create", upload.single("image"), function(req, res, next) {
    var image = new Image({
        name: req.body.image_name
    });
    image.img.data = fs.readFileSync(req.file.path);
    image.img.contentType = "image/jpg";
    image.save(function(err) {
        if (err) { return next(err); }
        res.redirect("/");
    });
});

// Show some random image
router.get("/image", function(req, res, next) {
    Image.findOne({}, function(err, image) {
        if (err) { return next(err); }
        res.contentType(image.img.contentType)
        res.send(image.img.data);
    });
});

image. js (схема изображения):

var mongoose = require("mongoose");

var Schema = mongoose.Schema;

var ImageSchema = new Schema(
    {
        name: {type: String, required: true, max: 100},
        img: {data: Buffer, contentType: String}
    }
);

module.exports = mongoose.model("Image", ImageSchema);

И, наконец, форма для создания изображений create_image.pug:

extends layout

block content
    h1= title

    form(action="" method="POST" enctype="multipart/form-data")
        label(for="image_name") Name of Image:
        input#image_name.form-control(type="text" placeholder="Name of image" name="image_name" required="true")
        input(type="file" name="image")
        button(type='submit') Submit

Это работает вроде хорошо, что изображение хранится в MongoDB Atlas, но оно также хранит изображения локально. Сейчас с точки зрения производства это не очень хорошая идея, так как проект станет большим. Однако я не могу понять, как сделать это правильно?

Может ли кто-нибудь сказать мне правильный способ сделать это, чтобы я мог хранить изображения только в MongoDB Atlas, а не локально? Также, возможно, скажите мне, если я все это неправильно, и должен ли я делать это совершенно по-другому?

1 Ответ

2 голосов
/ 02 марта 2020

Если вы не хотите хранить изображения локально, используйте MemoryStorage в качестве хранилища Multer.

var storage = multer.memoryStorage()
var upload = multer({ storage: storage })

При использовании хранилища в памяти информация о файле будет содержать поле с именем buffer, содержащее весь файл. , Так что вам не нужно звонить fs.readFileSync. Вы можете получить доступ к буферу с помощью req.file.image.buffer и назначить данные изображения;

image.img.data = req.file.image.buffer;
...