使用mongoose在mongodb中存储文件

时间:2014-11-27 09:39:52

标签: node.js mongodb file csv express

我是node和mongoDB的新手。我正在使用nodeJS,express和mongoDB开发一个应用程序。我想从文件输入字段读取csv / xlsx文件,并使用mongoose将其存储在mongoDB中。我遇到了困难。我在前端使用angularjs。谁能给我建议我应该通过什么程序?具体的代码将是很有帮助的。

我使用busboy模块将文件存储在特定文件夹中。这是我的代码

在路线中:

router.post('/fileupload', function (req, res) {
    var fstream;
    req.pipe(req.busboy);
    console.log(req.pipe);
    console.log(req.busboy);
    req.busboy.on('file', function (fieldname, file, filename) {
        console.log("Uploading: " + filename);
        fstream = fs.createWriteStream('./files/' + filename);
        file.pipe(fstream);
        fstream.on('close', function () {
            res.redirect('back');
        });
    });
});

和我的前端:

<form method="post" action="/fileupload" enctype="multipart/form-data">
    <input type="file" id="file" name="file">
    <button type="submit">Submit</button>
</form>

到目前为止没有错误。现在我只想将这些文件存储在数据库中。 接下来我该怎么办?

1 个答案:

答案 0 :(得分:4)

您可能需要了解在mongo中存储文件的基础。为什么文件存储在mongo中以及如何存储?

根据您的工作,您现在需要一个mongoose插件,将您上传的文件存储到mongo GridFS中。 GridFS在这里: - http://docs.mongodb.org/manual/core/gridfs/。你可以使用任何兼容的驱动程序访问网格 - mongoose和mongoose插件gridfs-stream就是一个例子 - 见这里:https://www.npmjs.org/package/gridfs-stream

我使用下面的文件将文件保存到gridfs中。

var express = require('express');
var formidable = require('formidable');
var mongoose = require('mongoose');
var grid = require('gridfs-stream');
var fs = require('fs');
var util = require('util');
var app = express();

app.post('/fileupload', function (req, res) {
    var form = new formidable.IncomingForm();
    form.uploadDir = __dirname + "/data";
    form.keepExtensions = true;
    form.parse(req, function(err, fields, files) {
        if (!err) {
          console.log('File uploaded : ' + files.file.path);
          grid.mongo = mongoose.mongo;
          var conn = mongoose.createConnection('..mongo connection string..');
          conn.once('open', function () {
          var gfs = grid(conn.db);
          var writestream = gfs.createWriteStream({
              filename: files.file.name
          });
          fs.createReadStream(files.file.path).pipe(writestream);
       });
     }        
   });
   form.on('end', function() {        
       res.send('Completed ..... go and check fs.files & fs.chunks in  mongodb');
   });

});

app.get('/', function(request, response){
    response.send(
        '<form method="post" action="/fileupload" enctype="multipart/form-data">'
        + '<input type="file" id="file" name="file">'
        + '<input type="submit" value="submit">'
        + '</form>'
        );    
});

app.listen(40000, function() {
    console.log('Express is listening on port 40000');
});

以上是关于如何在上传文件后继续操作的指南,它不是生产就绪的概念证明。请注意,我将busboy替换为强大的个人偏好。

是否可以帮助您继续前进?

SO1