Python Flask 接收前端上传的图片

为了编写一个Python接口来接收前端上传的图片、将其存储到本地并返回存储地址,你可以使用Flask框架,这是一个轻量级的Web框架,非常适合快速搭建Web应用。

以下是一个简单的示例,展示了如何实现这个功能:

  1. 首先,确保你已经安装了Flask。你可以使用以下命令安装:

    bash 复制代码
    pip install Flask
  2. 创建一个Python文件(例如 app.py),并编写以下代码:

python 复制代码
from flask import Flask, request, jsonify
import os
import uuid

app = Flask(__name__)

# 配置上传文件夹和允许的文件扩展名
UPLOAD_FOLDER = 'uploads'
ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'gif'}
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER

# 确保上传文件夹存在
if not os.path.exists(UPLOAD_FOLDER):
    os.makedirs(UPLOAD_FOLDER)

def allowed_file(filename):
    return '.' in filename and \
           filename.rsplit('.', 1)[1].lower() in ALLOWED_EXTENSIONS

@app.route('/upload', methods=['POST'])
def upload_file():
    # 检查是否有文件部分在请求中
    if 'file' not in request.files:
        return jsonify({'error': 'No file part'}), 400
    
    file = request.files['file']
    
    # 如果用户没有选择文件,浏览器也会提交一个空的文件名,没有文件内容
    if file.filename == '':
        return jsonify({'error': 'No selected file'}), 400
    
    if file and allowed_file(file.filename):
        filename = str(uuid.uuid4()) + '_' + file.filename
        filepath = os.path.join(app.config['UPLOAD_FOLDER'], filename)
        file.save(filepath)
        
        return jsonify({'message': 'File uploaded successfully', 'path': filepath}), 201
    else:
        return jsonify({'error': 'File type not allowed'}), 400

if __name__ == '__main__':
    app.run(debug=True)
  1. 运行你的Flask应用:

    bash 复制代码
    python app.py
  2. 现在,你可以使用Postman或其他HTTP客户端发送一个POST请求到 http://127.0.0.1:5000/upload,并在请求中包含一个文件(字段名为 file)。

示例请求(使用Postman)

  • URL: http://127.0.0.1:5000/upload
  • Method: POST
  • Body: form-data
    • Key: file
    • Value: 选择你要上传的图片文件

响应示例

如果上传成功,你将收到一个JSON响应,其中包含成功信息和图片存储路径,例如:

json 复制代码
{
    "message": "File uploaded successfully",
    "path": "uploads/xxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx_yourimage.jpg"
}

如果上传失败(例如文件类型不允许或没有选择文件),你将收到一个包含错误信息的JSON响应。

这个示例展示了基本的文件上传功能,但在生产环境中,你可能需要添加更多的错误处理、安全性措施(如验证上传者身份、限制上传大小等)以及日志记录功能。

相关推荐
liuyouzhang7 分钟前
将基于Archery的web数据库审计查询平台封装为jdbc接口的可行性研究(基于AI)
前端·数据库
u0109147605 小时前
CSS组件库如何快速扩展_通过Sass @extend继承基础布局
jvm·数据库·python
baidu_340998825 小时前
Golang怎么用go-noescape优化性能_Golang如何使用编译器指令控制逃逸分析行为【进阶】
jvm·数据库·python
m0_678485455 小时前
如何利用虚拟 DOM 实现无痕刷新?基于 VNode 对比的状态保持技巧
jvm·数据库·python
qq_342295825 小时前
CSS如何实现透明背景效果_通过RGBA色彩模式控制透明度
jvm·数据库·python
TechWayfarer5 小时前
知乎/微博的IP属地显示为什么偶尔错误?用IP归属地查询平台自检工具3步验证
网络·python·网络协议·tcp/ip·网络安全
xiaotao1315 小时前
02-机器学习基础: 监督学习——线性回归
学习·机器学习·线性回归
Greyson16 小时前
CSS如何处理超长文本换行问题_结合word-wrap属性
jvm·数据库·python
码事漫谈6 小时前
大模型输出的“隐性结构塌缩”问题及对策
前端·后端
justjinji6 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python