sql >> Database teknologi >  >> NoSQL >> MongoDB

Filoverførsel virker ikke med nodejs gridfs

Du skal muligvis tjekke dine værdier i parametre. Men forhåbentlig er det nært minimal prøve giver noget hjælp:

Opdater

Og det har hjulpet, fordi det fremhæver, at du slår _id op som et filnavn. I stedet bør du gøre dette:

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

hvis ikke

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

Siden _id feltet er forskelligt fra filnavnet

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. Hvorfor bruger MongoDB ikke indekskryds?

  2. Redis indtastede transaktioner

  3. Deserialiseringsgrænseflade i MongoDB ved hjælp af C# - Ukendt diskriminatorværdi

  4. Forespørgsel MongoDB søgning kun i bestemte timer