flask文件上传 flask-uploads

本文介绍如何使用Flask-Uploads扩展库实现文件上传功能,并结合Flask-WTF进行表单验证。此外,还展示了如何利用Pillow库生成图片缩略图。

官网 http://pythonhosted.org/Flask-Uploads/

  1. 说明:flask-uploads扩展库可以很好帮助你解决上传文件时的问题,使用非常方便

  2. 安装:pip install flask-uploads

  3. 配置:

    from flask_uploads import UploadSet, IMAGES
    from flask_uploads import configure_uploads, patch_request_class# 文件上传
    photos = UploadSet('photos', IMAGES)
    # 设置上传文件的地址
    app.config['UPLOADED_PHOTOS_DEST'] = os.getcwd()
    # 上传的初始化
    configure_uploads(app, photos)
    # 配置上传文件大小,默认64M,设置None则会采用MAX_CONTENT_LENGTH配置选项
    app.config['MAX_CONTENT_LENGTH'] = 2 * 1024 * 1024
    patch_request_class(app, size=None)
  4. 添加视图函数,如下:

    @app.route('/upload/', methods=['GET', 'POST'])
    def upload():
        img_url = None
        if request.method == 'POST' and 'photo' in request.files:
            # 生成随机的文件名
            suffix = os.path.splitext(request.files['photo'].filename)[1]
            filename = random_string() + suffix
            # 保存上传文件
            photos.save(request.files['photo'], name=filename)
            # 获取上传图片的URL
            img_url = photos.url(filename)
        return render_template('upload.html', img_url=img_url)
  5. 模板文件与原生文件上传相同

完整的文件上传

  1. 配置flask-uploads,同上

  2. 配置flask-wtf

    from flask_wtf import FlaskForm
    from flask_wtf.file import FileField, FileRequired, FileAllowed
    from wtforms import SubmitField# 文件上传表单
    class UploadForm(FlaskForm):
        photo = FileField(validators=[FileRequired(message='未选择文件'), 
                          FileAllowed(photos, message='只能上传图片')])
        submit = SubmitField('上传')
  3. 添加视图函数

    # 导入图片处理类库
    from PIL import Image@app.route('/upload/', methods=['GET', 'POST'])
    def upload():
        img_url = None
        form = UploadForm()
        if form.validate_on_submit():
            # 生成随机的文件名
            suffix = os.path.splitext(form.photo.data.filename)[1]
            filename = random_string() + suffix
    ​
            # 保存上传文件
            photos.save(form.photo.data, name=filename)
    ​
            # 生成缩略图
            pathname = os.path.join(app.config['UPLOADED_PHOTOS_DEST'], 
                                    filename)
            # 1.打开文件
            img = Image.open(pathname)
            # 2.设置尺寸
            img.thumbnail((128, 128))
            # 3.保存修改后的文件
            img.save(pathname)
    ​
            # 获取上传文件的URL
            img_url = photos.url(filename)
        return render_template('upload.html', form=form, img_url=img_url)
  4. 添加模板文件

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>完整的文件上传</title>
    </head>
    <body>
        <h1>图片上传,结合flask-wtf,flask-uploads,生成缩略图</h1>
        <form method="post" enctype="multipart/form-data">
            {{ form.hidden_tag() }}
            {{ form.photo() }}
            {% for error in form.photo.errors %}
                <span style="color: red;">{{ error }}</span>
            {% endfor %}
            {{ form.submit() }}
        </form>
        {% if img_url %}
            <img src="{{ img_url }}" />
        {% endif %}
    </body>
    </html>

    PIL只支持python2.x版本,社区开发人员对其进行了维护,以支持python3.x,

    使用时需要安装,方法如下:pip install pillow

编号 文件名称 cwts-specs-001 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:名语术语 cwts-specs-002 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:概述 cwts-specs-003 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理信道和传输信道到物理信道的映射 cwts-specs-004 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:信道编码与复用 cwts-specs-005 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:扩频与调制 cwts-specs-006 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理层过程 cwts-specs-007 IMT-DS FDD(WCDMA)系统无线接口物理层技术规范:物理层测量 cwts-specs-008 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:物理层向上层提供的服务 cwts-specs-009 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:MAC协议 cwts-specs-010 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:RLC协议 cwts-specs-011 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:PDCP协议 cwts-specs-012 IMT-DS FDD(WCDMA)系统无线接口层2技术规范:BMC协议 cwts-specs-013 IMT-DS FDD(WCDMA)系统无线接口层3技术规范:RRC协议 cwts-specs-014 IMT-DS FDD(WCDMA)系统Iu接口技术规范:概述 cwts-specs-015 IMT-DS FDD(WCDMA)系统Iu接口技术规范:层1技术要求 cwts-specs-016 IMT-DS FDD(WCDMA)系统Iu接口技术规范:信令传输 cwts-specs-017 IMT-DS FDD(WCDMA)系统Iu接口技术规范:RANAP信令 cwts-specs-018 IMT-DS FDD(WCDMA)系统Iu接口技术规范:数据传输和传输信令 cwts-specs-019 IMT-DS FDD(WCDMA)系统Iu接口技术规范:用户平面协议 cwts-specs-020 IMT-DS FDD(WCDMA)系统Iub接口技术规范:概述 cwts-specs-021 IMT-DS FDD(WCDMA)系统Iub接口技术规范:层1技术要求 cwts-specs-022 IMT-DS FDD(WCDMA)系统Iub接口技术规范:信令传输 cwts-specs-023 IMT-DS FDD(WCDMA)系统Iub接口技术规范:NBAP信令 cwts-specs-024 IMT-DS FDD(WCDMA)系统Iub接口技术规范:用于CCH数据流的数据传输和传输信令 cwts-specs-025 IMT-DS FDD(WCDMA)系统Iub接口技术规范:用于CCH数据流的用户平面协议 cwts-specs-026 IMT-DS FDD(WCDMA)系统Iur接口技术规范:概述 cwts-specs-027 IMT-DS FDD(WCDMA)系统Iur接口技术规范:层1技术要求 cwts-specs-028 IMT-DS FDD(WCDMA)系统Iur接口技术规范:信令传输 cwts-specs-029 IMT-DS FDD(WCDMA)系统Iur接口技术规范:RNSAP信令 cwts-specs-030 IMT-DS FDD(WCDMA)系统Iur接口技术规范:用于CCH数据流的数据传输和传输信令 cwts-specs-031 IMT-DS FDD(WCDMA)系统Iur接口技术规范:用于CCH数据流的用户平面协议 cwts-specs-032 IMT-DS FDD(WCDMA)系统Iub/Iur接口技术规范:用于DCH数据流的数据传输和传输信令 cwts-specs-033 IMT-DS FDD(WCDMA)系统Iub/Iur接口技术规范:用于DCH数据流的用户平面协议 cwts-specs-034 TD-SCDMA系统无线接口物理层技术规范 cwts-specs-035 TD-SCDMA系统无线接口层2技术规范 cwts-specs-036 TD-SCDMA系统无线接口层3-RRC技术规范 cwts-specs-037 TD-SCDMA系统Iu接口技术规范 cwts-specs-038 TD-SCDMA系统Iub接口技术规范 cwts-specs-039 TD-SCDMA系统Iur接口技术规范 cwts-specs-040 TD-SCDMA系统基站设备无线收发特性技术规范 cwts-specs-041 TD-SCDMA系统用户终端设备无线收发特性技术规范 CWTS发布的研究报告列表 cwts-reports-001 IMT-DS FDD(WCDMA)系统连接模式下的层间过程(25.303)标准研究报告 cwts-reports-002 IMT-DS FDD(WCDMA)系统空闲模式下UE的流程和连接模式下小区重选流程(25.304)标准研究报告 cwts-reports-003 IMT-DS FDD(WCDMA)系统无线资源管理RRM研究报告 cwts-reports-004 IMT-DS FDD(WCDMA)系统无线资源管理RRM研究报告 cwts-reports-005 IMT-DS FDD(WCDMA)系统UE无线接入能力研究报告
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值