Загрузка GridFs с использованием nodejs не начинается

Я пытаюсь загрузить двоичный файл +200M, сохраненный в mongoDB, используя GridFS. Моя проблема в том, что загрузка не начинается. Я использую nodejs с mongodb и gridfs-stream.

В маршрутах.js:

router.get('/getlog',function(req,res) {
    if (req.isAuthenticated())
    {
        var mongo = require('mongodb');
        var Grid = require('gridfs-stream');
        var db = new mongo.Db('logApp', new mongo.Server("127.0.0.1", 27017));

        db.open(function (err) {
            if (err) 
                return handleError(err);
        });

        var gfs = Grid(db, mongo);
        var id = req.query.id;
        gfs.exist({_id: id}, function (err, found) {
            if (err) return handleError(err);
            if (!found)
                res.send('Error on the database looking for the file.')
        });

        var readStream = gfs.createReadStream({
            _id: id
        }).pipe(res);
    }
    else
        res.redirect('/login');
});

Где-то на мой взгляд:

td #[a(href="getlog?id=#{log.logId}", download="logfile") #[span(name='log').glyphicon.glyphicon-download]]

который генерирует ответ из журнала nodejs:

GET /getlog?id=55818770b276172922b945b8 - - ms - -

но загрузка никогда не начинается... и я понятия не имею, что происходит..

1 ответ

Решение

Менять

gfs.exist({_id: id}, function (err, found) {
            if (err) return handleError(err);
            if (!found)
                res.send('Error on the database looking for the file.')
        });

        var readStream = gfs.createReadStream({
            _id: id
        }).pipe(res);

в

gfs.exist({_id: id}, function (err, found) {
            if (err) return handleError(err);
            if (!found)
                return res.send('Error on the database looking for the file.');
            gfs.createReadStream({_id: id}).pipe(res);
        });

Пожалуйста, попробуй.

Другие вопросы по тегам