Я использую mongoose и gridfs-stream для хранения и чтения файлов из mongodb. Я следую примеру здесь: https://github.com/aheckmann/gridfs-stream
Запись файлов в БД работает нормально, но я столкнулся с проблемой чтения файлов.
Как выглядит mongodb (показать коллекции)
fs.chunks
fs.files
Как выглядит файловый индекс (db.fs.files.find())
{ "_id" : ObjectId("5140392659851df70b000001"),
"filename" : "cover",
"contentType" : "binary/octet-stream",
"length" : 85734,
"chunkSize" : 262144,
"uploadDate" : ISODate("2013-03-13T08:30:30.299Z"),
"aliases" : null,
"metadata" : null,
"md5" : "4476b26067daa0677978ba501308a35d" }
Затем я использую этот код, чтобы получить файл с именем «обложка».
...
var gfs = Grid(mongoose.connection.db, mongoose.mongo)
var readstream = gfs.createReadStream('cover')
Произошла ошибка:
Error: cover does not exist
at self.collection.self.fileId (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/gridfs/gridstore.js:198:26)
at Cursor.nextObject (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/cursor.js:654:35)
at Cursor.close (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/cursor.js:960:5)
at Cursor.nextObject (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/cursor.js:654:17)
at Cursor.nextObject.commandHandler (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/cursor.js:631:14)
at Db._executeQueryCommand (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/db.js:1702:5)
at g (events.js:185:14)
at EventEmitter.emit (events.js:115:20)
at Server.Base._callHandler (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/connection/base.js:130:25)
at Server.connect.connectionPool.on.server._serverState (/mypath/node_modules/mongoose/node_modules/mongodb/lib/mongodb/connection/server.js:517:20)
Я погуглил и нашел несколько возможных связанных ссылок:
https://github.com/mongodb/node-mongodb-native/issues/ 621а>
Почему gridfs получает не не работает с идентификатором файла (ObjectId) только по имени файла
var readstream = gfs.createReadStream('5140392659851df70b000001')
. Я предполагаю, что причина связана с установкой ключа? - person LKS   schedule 13.03.2013