【问题标题】:Using MongoDB, Express, Node.Js and GridFS-stream for storing video and picture files使用 MongoDB、Express、Node.Js 和 GridFS-stream 存储视频和图片文件
【发布时间】:2015-09-23 23:12:09
【问题描述】:

我正在使用 JavaScript(JQuery) 创建一个单页应用程序,并且需要存储大小超过 16Mb 的大型视频文件。我发现需要使用支持大文件的GridFS。由于我是 MongoDB 的新手,我不确定如何使用 GridFS。有一些关于使用 Node.js、MongoDB 和 Express 创建应用程序的好教程,但找不到任何描述如何将 GridFS 与 MongoDB(不是 mongoose)、Express 和 Node.js 一起使用的教程。我设法以 16MB 的 BSON 文档大小限制上传文件。这就是我所拥有的:

var express = require('express');
var path = require('path');
var bodyParser = require('body-parser');
var mongo = require('mongodb');
var monk = require('monk');
var Grid = require('gridfs-stream');

var db = monk('localhost:27017/elearning');
var gfs = Grid(db, mongo);

var routes = require('./routes/index');
var users = require('./routes/users');
var courses = require('./routes/courses');

var app = express();

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');


app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

// Make our db accessible to our router
app.use(function(req,res,next){
  req.db = db;
  next();
});

app.use('/', routes);
app.use('/users', users);
app.use('/courses', courses);

// catch 404 and forward to error handler
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
      message: err.message,
      error: err
    });
  });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render('error', {
    message: err.message,
    error: {}
  });
});


module.exports = app;

例如,课程文件如下:

var express = require('express');
var router = express.Router();

/* GET courses listing */
router.get('/courselist', function(req, res) {
    var db = req.db;
    var collection = db.get('courselist');
    collection.find({},{},function(e,docs){
        res.json(docs);
    })

});

/* POST courses data */
router.post('/courselist', function(req, res) {
    var db = req.db;
    var collection = db.get('courselist');
    collection.insert(req.body, function(err, result){
        res.send(
            (err === null) ? { msg: '' } : { msg: err }
        );
    });
});

/* Delete courses data */
router.delete('/courselist/:id', function(req, res) {
    var db = req.db;
    var collection = db.get('courselist');
    var userToDelete = req.params.id;
    collection.remove({ '_id' : userToDelete }, function(err) {
        res.send((err === null) ? { msg: '' } : { msg:'error: ' + err });
    });
});

module.exports = router;

如果您能告诉我应该如何编辑上述文件以利用 GridFS 并能够从我的电子学习数据库中获取、上传和删除视频和图片文件,我将非常感谢您的帮助。

【问题讨论】:

    标签: javascript node.js mongodb express gridfs


    【解决方案1】:

    您可以在不使用mongoose 的情况下使用gridfs-stream 直接上传,如下所示:

    var express = require('express'),
        mongo = require('mongodb'),
        Grid = require('gridfs-stream'),
        db = new mongo.Db('node-cheat-db', new mongo.Server("localhost", 27017)),
        gfs = Grid(db, mongo),
        app = express();
    
    db.open(function (err) {
        if (err) return handleError(err);
        var gfs = Grid(db, mongo);
        console.log('All set! Start uploading :)');
    });
    
    //POST http://localhost:3000/file
    app.post('/file', function (req, res) {
        var writeStream = gfs.createWriteStream({
            filename: 'file_name_here'
        });
        writeStream.on('close', function (file) {
            res.send(`File has been uploaded ${file._id}`);
        });
        req.pipe(writeStream);
    });
    
    //GET http://localhost:3000/file/[mongo_id_of_file_here]
    app.get('/file/:fileId', function (req, res) {
        gfs.createReadStream({
            _id: req.params.fileId // or provide filename: 'file_name_here'
        }).pipe(res);
    });
    
    app.listen(process.env.PORT || 3000);
    

    完整的文件和正在运行的项目:

    克隆节点作弊direct_upload_gridfs,运行node app,然后运行npm install express mongodb gridfs-stream

    在 Node-Cheat Direct Upload via GridFS README.md 跟随婴儿步骤

    【讨论】:

    • 这个例子很好,但是你能告诉我如何运行这个例子吗?
    • @Kaushal28 请查看更新后的答案,有关分步指导,您可以跳至上述 README.md 链接。
    • 非常感谢您提供分步指南。现在我面临的问题是db.open() 不是函数。我认为这是因为节点或 mongo db 的版本差异。所以我把你的代码改成了这个:gist.github.com/Kaushal28/d607371a2f95df4ebc356ca04294a8de
    • 但是现在我遇到了一些奇怪的错误:TypeError: Cannot read property 'readPreference' of null 当我通过邮递员发布请求时,如您的屏幕截图所示。再次感谢。
    • 我也尝试过使用 MongoClient 但得到同样的错误。
    【解决方案2】:

    很晚了,但我发现以前的答案已经过时了。我发布这个是因为这可能会帮助像我这样的新手。要运行它,请按照以前的答案指南。所有功劳归于@ZeeshanHassanMemon。

    var express = require('express'),
    mongoose = require('mongoose'),
    Grid = require('gridfs-stream'),
    app = express();
    
    Grid.mongo = mongoose.mongo;
     conn = mongoose.createConnection('mongodb://localhost/node-cheat-db');
      conn.once('open', function () {
        var gfs = Grid(conn.db);
        app.set('gridfs', gfs);
        console.log('all set');
      });
    
    //POST http://localhost:3000/file
    app.post('/file', function (req, res) {
         var gridfs = app.get('gridfs');
        var writeStream = gridfs.createWriteStream({
            filename: 'file_name_here'
        });
        writeStream.on('close', function (file) {
            res.send(`File has been uploaded ${file._id}`);
        });
        req.pipe(writeStream);
    });
    
    //GET http://localhost:3000/file/[mongo_id_of_file_here]
    app.get('/file/:fileId', function (req, res) {
        var gridfs = app.get('gridfs');
        gridfs.createReadStream({
            _id: req.params.fileId // or provide filename: 'file_name_here'
        }).pipe(res);
    });
    
    app.listen(process.env.PORT || 3000);
    

    【讨论】:

      猜你喜欢
      • 2015-07-18
      • 1970-01-01
      • 2015-04-06
      • 2013-10-27
      • 2015-06-29
      • 2016-04-05
      • 1970-01-01
      • 2011-06-26
      • 1970-01-01
      相关资源
      最近更新 更多