所以我存储的图像是这样的:
router.post('/', upload.single('pic'), (req, res) => {
var newImg = fs.readFileSync(req.file.path);
var encImg = newImg.toString('base64');
var s = new Buffer(encImg, 'base64');
var newCar = {
picture: s,
contentType: req.file.mimetype,
link: req.body.link
}
})
});
现在数据如下所示:
{
_id: 5a502869eb1eb10cc4449335,
picture: Binary { _bsontype: 'Binary',
sub_type: 0,
position: 1230326,
buffer: <Buffer 89 50 4e 47 0d 0a 1a 0a 00 00 00 0d 49
48 44 52 00 00 05 00 00 00 03 1e 08 06 00 ... >
},
contentType: 'image/png',
link: 'fds',
__v: 0
}
我想在前端展示这张照片,如下:
<img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
就我而言,这段代码将是:
<img src="data:<%= c.contentType %>;base64, <%= c.picture %>" />
我想我几乎尝试了一切,但仍然无法弄清楚这是什么。即使我将缓冲区转换为字符串(&#39; ascii&#39;),我仍然会得到一些无法识别的符号(方框)。
我该怎么办? 附:此外,这是存储图像的好方法吗? (小于16MB),我想我注意到它有点慢,因为那些长字符串转换和读取文件,与我只是将图像存储为文件的情况相比?
答案 0 :(得分:0)
HTML
<img [src]="'data:image/jpg;base64,'+Logo.data" height="50" width="60" alt="Red dot" />
数据库中的数据:
"Logo" : {
"data" : BinData(0,"/9j/4AAQSkZJRgABAQEAYABgAAD/"),
"name" : "dp.jpg",
"encoding" : "7bit",
"mimetype" : "image/jpeg",
"truncated" : false,
"size" : 895082
}
希望有所帮助