使用python flask框架开发图片上传接口的案例详解
作者:大蛇王 发布时间:2021-12-26 05:54:30
标签:python,flask,图片上传,接口
python版本:3.6+
需要模块:flask,pillow
需求:开发一个支持多格式图片上传的接口,并且将图片压缩,支持在线预览图片。
目录结构:
app.py编辑内容:
from flask import Flask, request, Response, render_template
from werkzeug.utils import secure_filename
import os
import uuid
from PIL import Image, ExifTags
app = Flask(__name__) # 实例Flask应用
# 设置允许上传的文件格式
ALLOW_EXTENSIONS = ['png', 'jpg', 'jpeg']
# 设置图片保存文件夹
app.config['UPLOAD_FOLDER'] = './static/image/'
# 设置图片返回的域名前缀
image_url = "http://127.0.0.1:8002/image/"
# 设置图片压缩尺寸
image_c = 1000
# 跨域支持
def after_request(resp):
resp.headers['Access-Control-Allow-Origin'] = '*'
return resp
app.after_request(after_request)
# 判断文件后缀是否在列表中
def allowed_file(filename):
return '.' in filename and filename.rsplit('.', 1)[-1] in ALLOW_EXTENSIONS
# 首页
@app.route('/')
def hello_world():
return render_template('index.html')
# 心跳检测
@app.route("/check", methods=["GET"])
def check():
return 'Im live'
# 图片获取地址 用于存放静态文件
@app.route("/image/<imageId>")
def get_frame(imageId):
# 图片上传保存的路径
try:
with open(r'./static/image/{}'.format(imageId), 'rb') as f:
image = f.read()
result = Response(image, mimetype="image/jpg")
return result
except BaseException as e:
return {"code": '503', "data": str(e), "message": "图片不存在"}
# 上传图片
@app.route("/upload_image", methods=['POST', "GET"])
def uploads():
if request.method == 'POST':
# 获取文件
file = request.files['file']
# 检测文件格式
if file and allowed_file(file.filename):
# secure_filename方法会去掉文件名中的中文,获取文件的后缀名
file_name_hz = secure_filename(file.filename).split('.')[-1]
# 使用uuid生成唯一图片名
first_name = str(uuid.uuid4())
# 将 uuid和后缀拼接为 完整的文件名
file_name = first_name + '.' + file_name_hz
# 保存原图
file.save(os.path.join(app.config['UPLOAD_FOLDER'], file_name))
# 以下是压缩图片的过程,在原图的基础上
file_min = Image.open(file)
# exif读取原始方位信息 防止图片压缩后发生旋转
try:
for orientation in ExifTags.TAGS.keys():
if ExifTags.TAGS[orientation] == 'Orientation': break
exif = dict(file_min._getexif().items())
if exif[orientation] == 3:
file_min = file_min.rotate(180, expand=True)
elif exif[orientation] == 6:
file_min = file_min.rotate(270, expand=True)
elif exif[orientation] == 8:
file_min = file_min.rotate(90, expand=True)
except:
pass
# 获取原图尺寸
w, h = file_min.size
# 计算压缩比
bili = int(w / image_c)
# 按比例对宽高压缩
file_min.thumbnail((w // bili, h // bili))
# 生成缩略图的完整文件名
file_name_min = first_name + '_min.' + file_name_hz
# 保存缩略图
file_min.save(os.path.join(app.config['UPLOAD_FOLDER'], file_name_min))
# 返回原本和缩略图的 完整浏览链接
return {"code": '200', "image_url": image_url + file_name, "image_url_min": image_url + file_name_min,
"message": "上传成功"}
else:
return "格式错误,仅支持jpg、png、jpeg格式文件"
return {"code": '503', "data": "", "message": "仅支持post方法"}
if __name__ == "__main__":
app.run(host="0.0.0.0", port=8002, debug=True) # 项目入口
运行app.py
使用postman对接口进行测试:
返回结果:
从浏览器打开查看:
我们打开文件夹查看图片:
可以看出,压缩后的图片和原图的大小。
完工!(注释的很详细,就不想打字了)
来源:https://blog.csdn.net/t8116189520/article/details/124118017


猜你喜欢
- 目录1、背景2、C# 语言3、Python 语言4、技术分析1、背景我们先看这个题目:标题:137. 只出现一次的数字 II难度:中等htt
- 关于Pytorch中怎么自定义Dataset数据集类、怎样使用DataLoader迭代加载数据,这篇官方文档已经说得很清楚了,这里就不在赘述
- 本文为大家分享了VMWare linux安装mysql 5.7.13的教程,供大家参考,具体内容如下1、基础环境说明虚拟机:VMWare操作
- 本文实例讲述了php设计模式之适配器模式。分享给大家供大家参考,具体如下:星际的很多兵种,都有至少一项特殊技能。而且有些兵种的技能是相同的,
- 1. 像素基本操作1.1 读取、修改像素可以通过[行,列]坐标来访问像素点数据,对于多通道数据,返回一个数组,包含所有通道的值,对于单通道数
- 本文实例讲述了sogou地图API应用,是非常实用的技巧。分享给大家供大家参考。具体实现方法如下:地图的初始化1、添加引用地图的API文件:
- 设置表名为中文1.设置Models.py文件class Post(models.Model): name = models.CharFiel
- 项目需要在electron的项目中新打开一个窗口,利用webpack作为静态资源打包器,发现在webpack中可以设置多页面的入口,今天来讲
- 给内存和cpu使用量设置限制在linux系统中,使用Python对内存和cpu使用量设置限制需要通过resource模块来完成。resour
- 1、设置无头浏览器模式from selenium import webdriverfrom selenium.webdriver.chrom
- 关于这篇文章有几句话想说,首先给大家道歉,之前学的时候真的觉得下述的是比较厉害的东西,但是后来发现真的是基础中的基础,内容还不是很完全。再看
- 一、安装mongo plugs插件File->SettingPlugins查询Mongo选择Search in repositorie
- 创建一个示例数据框:import pandas as pddf = pd.DataFrame([['乔峰', '男&
- 题目:来自Madrid且订单数少于3的消费者 建表:set nocount on --当 SET NOCOUNT 为
- cos()方法返回x弧度的余弦值。语法以下是cos()方法的语法:cos(x)注意:此函数是无法直接访问的,所以我们需要导入ma
- 前言大家好,我是Peter~本文记录的是Pandas两种少用的读取文件方式:读取在线文件的数据读取剪贴板的数据声明:本文案例和在线数据仅用于
- 通过python与ffmpeg结合使用,可生成进行视频点播、直播的压力测试脚本。可支持不同类型的视频流,比如rtmp或者hls形式。 通过如
- 本文实例为大家分享了python实现石头剪刀布的具体代码,供大家参考,具体内容如下老师布置了一个石头剪刀布的作业,要可视化,还是先用代码实现
- 今天给大家分享一下最新版阿里大于的短信验证码在node koa2的实现,还是有很多坑需要注意。首先需要在阿里云注册账号,并获取阿里云访问秘钥
- __import__() 函数用于动态加载类和函数 。如果一个模块经常变化就可以使用 __import__() 来动态载入。语法__impo