flask简单加载图片数据流

本文介绍了在Flask应用中,由于图片请求堆积导致get方法无法获取所有图片的问题,提供了一个使用BytesIO和队列优化的简单解决方案。作者提到,虽然文章中的示例仅适用于基础演示,但结合队列是最佳实践。
摘要由CSDN通过智能技术生成

之所以get获取不到图片,是因为请求都堆积在同一个时间点了,未能等待文件读取完毕。

一个页面有多张图片时常常只能显示前几张

简单的处理方式如下:

# 依赖
from io import BytesIO
from flask import make_response

# 视图
@app.route('/data/image/<filename>',methods=['GET'])
def image_cache(filename):
    img=open('data/image/{}'.format(filename),"rb")
    img_io=BytesIO(img.read())
    data=img_io.getvalue()
    img_io.close()
    response=make_response(data)
    response.headers['Content-Type']='image/png'
    return response

其实最好的方式应该是结合队列。但这个写法在简单demo展示中应该够用了...

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值