使用python flask框架開發(fā)圖片上傳接口的案例詳解
python版本:3.6+
需要模塊:flask,pillow
需求:開發(fā)一個支持多格式圖片上傳的接口,并且將圖片壓縮,支持在線預(yù)覽圖片。
目錄結(jié)構(gòu):
app.py編輯內(nèi)容:
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應(yīng)用 # 設(shè)置允許上傳的文件格式 ALLOW_EXTENSIONS = ['png', 'jpg', 'jpeg'] # 設(shè)置圖片保存文件夾 app.config['UPLOAD_FOLDER'] = './static/image/' # 設(shè)置圖片返回的域名前綴 image_url = "http://127.0.0.1:8002/image/" # 設(shè)置圖片壓縮尺寸 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' # 圖片獲取地址 用于存放靜態(tài)文件 @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)) # 以下是壓縮圖片的過程,在原圖的基礎(chǔ)上 file_min = Image.open(file) # exif讀取原始方位信息 防止圖片壓縮后發(fā)生旋轉(zhuǎn) 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對接口進行測試:
返回結(jié)果:
從瀏覽器打開查看:
我們打開文件夾查看圖片:
可以看出,壓縮后的圖片和原圖的大小。
完工?。ㄗ⑨尩暮茉敿?,就不想打字了)
到此這篇關(guān)于使用python flask框架開發(fā)圖片上傳接口的案例詳解的文章就介紹到這了,更多相關(guān)python flask框架開發(fā)圖片上傳接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Django實現(xiàn)從數(shù)據(jù)庫中獲取到的數(shù)據(jù)轉(zhuǎn)換為dict
這篇文章主要介紹了Django實現(xiàn)從數(shù)據(jù)庫中獲取到的數(shù)據(jù)轉(zhuǎn)換為dict,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03Conda環(huán)境導(dǎo)出與導(dǎo)入的實現(xiàn)
本文主要介紹了Conda環(huán)境導(dǎo)出與導(dǎo)入的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧2023-03-03pycharm中django框架連接mysql數(shù)據(jù)庫的方法
這篇文章主要介紹了pycharm中django框架連接mysql數(shù)據(jù)庫的方法,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04pygame+opencv實現(xiàn)讀取視頻幀的方法示例
由于pygame.movie.Movie.play()只支持MPEG格式的視頻,所以決定使用與opencv讀取視頻幀的畫面,本文就詳細的介紹了pygame+opencv實現(xiàn)讀取視頻幀,感興趣的可以了解一下2021-12-12