在模板中显示存储为二进制 blob 的图像

Posted

技术标签:

【中文标题】在模板中显示存储为二进制 blob 的图像【英文标题】:Display image stored as binary blob in template 【发布时间】:2021-10-29 16:21:00 【问题描述】:

我有一个模型,其图像存储为二进制 blob。我想在模板中显示此图像以及有关对象的其他数据。由于图像不是单独的文件,我不知道如何显示它。我试过设置标题,或者使用send_filerender_template,但我要么没有得到图像,要么 得到图像而不是模板的其余部分。如何在模板中将二进制 blob 显示为图像?

class A(ndb.Model):
    id= ndb.IntegerProperty()
    x= ndb.StringProperty()
    y= ndb.StringProperty()
    image = ndb.BlobProperty()

【问题讨论】:

【参考方案1】:

图像以字节形式存储。使用 base64 对其进行编码,并将其作为数据 URI 插入到呈现的 html 中。您可以将对象及其编码图像都传递给模板。

from base64 import b64encode

@app.route("/show/<int:id>")
def show(id):
    obj = A.query(A.id == id).fetch(1)[0]
    image = b64encode(obj.image).decode("utf-8")
    return render_template("show_a.html", obj=obj, image=image)
<p> obj.x <br/>
 obj.y </p>
<img src="data:;base64, image "/>

这是次优的,因为每次呈现页面时都会发送数据 URI,而客户端可以缓存图像文件。最好将图片文件存放在目录中,将路径存放在数据库中,单独提供图片文件即可。

【讨论】:

以上是关于在模板中显示存储为二进制 blob 的图像的主要内容,如果未能解决你的问题,请参考以下文章

以字节数组和二进制 (BLOB) 存储图像之间的区别以及哪个更快

如何将二进制数据作为图像写入 azure blob 存储 c#

MySQL - Base64 vs BLOB

使用 JavaScript 将 png 图像转换为 blob 图像?

XSL - 显示存储为 blob 的图像

cehsi