技术文摘
在Flask中怎样读取MySQL数据库里的图片并返回至前端
2025-01-14 17:33:45 小编
在Flask中怎样读取MySQL数据库里的图片并返回至前端
在Web开发中,经常会遇到需要从数据库读取图片并展示到前端页面的需求。本文将详细介绍在Flask框架中,如何读取MySQL数据库里的图片并返回至前端。
确保安装了必要的库。Flask是核心的Web框架,需要安装它以及用于连接MySQL数据库的mysql-connector-python库。可以通过pip install flask mysql-connector-python来完成安装。
接着,在Flask应用中建立与MySQL数据库的连接。示例代码如下:
import mysql.connector
from flask import Flask, send_file
import io
app = Flask(__name__)
def get_image_from_db():
mydb = mysql.connector.connect(
host="localhost",
user="your_username",
password="your_password",
database="your_database"
)
mycursor = mydb.cursor()
mycursor.execute("SELECT image_column FROM your_table WHERE id = 1")
result = mycursor.fetchone()
mydb.close()
if result:
return result[0]
return None
上述代码定义了一个get_image_from_db函数,它连接到MySQL数据库,执行查询语句,从指定表中获取图片数据,查询完成后关闭数据库连接。
然后,创建一个Flask路由来返回图片。代码如下:
@app.route('/get_image')
def get_image():
image_data = get_image_from_db()
if image_data:
return send_file(
io.BytesIO(image_data),
mimetype='image/jpeg'
)
return "图片未找到"
在这个路由中,调用get_image_from_db函数获取图片数据。如果获取到数据,使用send_file函数将图片数据作为响应返回给前端,并设置正确的MIME类型。如果未找到图片,则返回相应的提示信息。
最后,启动Flask应用:
if __name__ == '__main__':
app.run(debug=True)
在前端页面,通过<img>标签的src属性指向/get_image路由,即可实现图片的展示。例如:<img src="/get_image" alt="图片">。
通过以上步骤,就能在Flask应用中顺利读取MySQL数据库里的图片并展示到前端页面。这个过程涉及到数据库连接、数据查询、数据处理以及前端展示多个环节,每个环节都需要仔细处理,确保系统的稳定运行和良好用户体验。
- 性能测试中基础曲线模型的分析之道
- 提升 Spring Data JPA 性能的四个技巧,让程序更流畅!
- 低代码:摒弃繁琐 加速软件开发
- 性能测试的指标与术语
- 19 个常用的 JavaScript 数组方法总结 赶紧收藏
- 这款开发工具助程序员告别 996 爆火
- Nginx map 助力时间格式的转换
- 微服务架构中 API 网关的发展趋向深入剖析
- 反驳:放弃 TypeScript 是无知之举
- 从得物 SRE 视角看蓝绿发布
- 轻松搞懂 Kubernetes 编排工具 Minikube
- 我为何更青睐基于主干的开发
- 企业变革管理对供应链困境的缓解作用
- Spring 所支持的数据类型注入详解,你用过哪些?
- JsonPath 详细使用教程:你知晓多少?