正在从MongoDB读取二进制文件



我目前正在做一个项目,该项目涉及上传图像和视频,然后将它们保存到MongoDB。我正在使用multer和GridF来实现这一点。图像和视频以二进制格式保存。现在,我有一个小问题,我想能够打开图像文件并使用Jimp进行一些图像操作,但我不知道如何实现这一点。

这是从数据库返回的内容,即fs.chunk集合

found: {
_id: 5ff5fe1f6461621e34f124d5,
files_id: 5ff5fe1f6461621e34f124d4,
n: 0,
data: Binary {
_bsontype: 'Binary',
sub_type: 0,
position: 261120,
buffer: <Buffer ff d8 ff e0 00 10 4a 46 49 46 00 01 01 01 00 48 00 48 00 00 ff e2 0c 58 49 43 43 5f 50 52 4f 46 49 4c 45 00 01 01 00 00 0c 48 4c 69 6e 6f 02 10 00 00 ... 261070 more bytes>
}
}

这是存储在fs.files集合中的内容

fieldname: 'avatar',
originalname: 'CMG - Bright Future Blaze.jpg',
encoding: '7bit',
mimetype: 'image/jpeg',
id: 5ff5fabcbcd9bb26c8896ce6,
filename: 'ef96af4bd209f827963aa9580196e453.jpg',
metadata: null,
bucketName: 'uploads',
chunkSize: 261120,
size: 391319,
md5: '10782da2083a3f1f201ba6f33748da62',
uploadDate: 2021-01-06T18:00:28.382Z,
contentType: 'image/jpeg'

从上面的片段中,filename列在那里,但我的问题实际上是打开这个文件并进行一些图像处理。如有任何帮助,我们将不胜感激。如果我尝试使用data.toString('base64')转换二进制数据,它会输出[object ArrayBuffer]

数据属性实际上是ArrayBuffer,而不是Buffer。如果您引用Buffer上的文档。你应该能够做

Buffer.from(data).toString('base64')

最新更新