技术文摘
在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数据库里的图片并展示到前端页面。这个过程涉及到数据库连接、数据查询、数据处理以及前端展示多个环节,每个环节都需要仔细处理,确保系统的稳定运行和良好用户体验。
- jQuery升级踩坑大全经典推送
- CSS 边框图像助你打造精美网站
- 15位健在的厉害程序员,你了解哪几位
- 深入理解 Java 类加载器热点推荐
- 2015 年开源前端框架前 20 强盘点
- Java开发不可或缺的IntelliJ IDEA插件
- ThinkJS 2.1版发布,支持TypeScript,性能大幅提升
- Web 开发人员必知的十款 HTML5 响应式框架
- AngularJS在实际应用中的那些事儿探讨
- PHP OCR 实战:借助 Tesseract 读取图像文字
- 逐步剖析Java企业级应用的可扩展性
- 技术团队负责人需具备哪些能力
- 10个超炫酷的jQuery相册动画鉴赏
- 我的 1 万小时编程所得
- Java EE 7 中的编程式 WebSocket 端点