显示来自MongoDB的图像,该图像存储为缓冲区

时间:2018-01-06 15:16:12

标签: node.js mongodb mongoose

所以我存储的图像是这样的:

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 %>" />

我得到的只是一些奇怪的符号: Image of FrontEnd Console

我想我几乎尝试了一切,但仍然无法弄清楚这是什么。即使我将缓冲区转换为字符串(&#39; ascii&#39;),我仍然会得到一些无法识别的符号(方框)。

我该怎么办? 附:此外,这是存储图像的好方法吗? (小于16MB),我想我注意到它有点慢,因为那些长字符串转换和读取文件,与我只是将图像存储为文件的情况相比?

1 个答案:

答案 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
    }

希望有所帮助