我使用长 blob 创建了一个数据库并将图像存储在其中。然后我想将图像显示到我的 ejs 网页之一。然而,它显示为奇怪的字体。我知道我应该对其进行转换,以便它可以工作,但我只是不知道该怎么做。
这是我在 ejs 中使用的代码:
<% for (var i = 0; i < products.length; i++) { console.log(products[i]); %>
<div class="row">
<div class="cell" data-title="Brand">
<td><%= products[i].brand %></td>
</div>
<div class="cell" data-title="Model">
<td><%= products[i].model %></td>
</div>
<div class="cell" data-title="Series">
<td><%= products[i].series %></td>
</div>
<div class="cell" data-title="Preview">
<td><img src="data:image/jpeg;base64,<%- products[i].image01 %>" /></td>
</div>
</div>
<% } %>
有很多帖子展示了如何在 javascript 中做到这一点,但是有没有办法在 ejs 中做到这一点?另外,我发现的大多数方法看起来都很长,所以我试图尽可能高效。请帮忙!
最佳答案
根据我的理解,您需要将二进制数据转换为base64格式,然后将其传递给ejs。您可以在 NodeJS 中使用 Buffer
来完成此操作。
试试这个:
products[i] = new Buffer(products[i]).toString('base64');
希望这有帮助!
关于mysql - 如何将类型 blob 图像显示到 ejs 网页?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51692042/