sql >> Databasteknik >  >> NoSQL >> MongoDB

Filnedladdning fungerar inte med nodejs gridfs

Du kan behöva kontrollera dina värden i parametrar. Men förhoppningsvis detta nära minimal sample ger lite hjälp:

Uppdatera

Och det har hjälpt, eftersom det framhäver att du letar upp _id som ett filnamn. Istället bör du göra så här:

.createReadStream({
    _id: req.param('filename')
})

om inte

.createReadStream({
    _id: mongoose.Types.ObjectId(req.param('filename'))
})

Sedan _id fältet skiljer sig från filnamnet

app.js

var express = require('express');
var routes = require('./routes');
var http = require('http');
var path = require('path');

var app = express();

var mongoose = require('mongoose');
var Grid = require('gridfs-stream');
Grid.mongo = mongoose.mongo;

var conn = mongoose.createConnection('mongodb://localhost/mytest');

conn.once('open', function() {
    console.log('opened connection');
    gfs = Grid(conn.db);

    // all environments
    app.set('port', process.env.PORT || 3000);
    app.use(express.logger('dev'));
    app.use(app.router);

    // development only
    if ('development' == app.get('env')) {
        app.use(express.errorHandler());
    }

    app.get('/', routes.index);

    http.createServer(app).listen(app.get('port'), function(){
        console.log('Express server listening on port ' + app.get('port'));
    });

});

routes/index.js

exports.index = function(req, res){

    res.set('Content-Type', 'image/jpeg');
    gfs.createReadStream({
        filename: 'receptor.jpg'
    }).pipe(res);

};



  1. Sortera dokument efter värde i det sista elementet i en array som matchar filter. Mongodb

  2. Tillfälligt fel i namnupplösning redis

  3. mongodb få senast infogade dokument

  4. MongoDB dra element från array två nivåer djup