Flask 文件上传方法(详解版)

Flask 是一个轻量级的 Web 框架,提供了简洁的 API 和易于使用的工具,使得开发 Web 应用程序变得更加简单。

在本文中,我们将深入探讨 Flask 中的文件上传功能。

首先,在 Flask 中使用文件上传,需要用到 werkzeug 模块的 FileStorage 类。FileStorage 可以将上传的文件转换为特定类型的表示,以便在应用程序中进行处理。

接着,我们需要一个 HTML 表单来允许用户选择文件并将其上传到服务器。

HTML 表单的结构如下所示:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>文件上传</title>
  </head>
  <body>
    <h1>上传文件</h1>
    <form action="file_upload" method="post" enctype="multipart/form-data">
      <input type="file" name="file">
      <br><br>
      <input type="submit" value="上传">
    </form>
  </body>
</html>

在 form 标签中,我们设定了 action 属性为 file_upload,表明在提交表单时会将数据发送到 /file_upload 路由上进行处理。method 属性为 post,表示使用 POST 方法发送请求。enctype 属性为 multipart/form-data,是指表单中包含二进制数据(如上传的文件),需要使用该属性来指明表单数据的 MIME 类型。

在 input 标签中,type 属性为 file,表示允许用户选择文件进行上传。name 属性为 file,用于后端处理时的参数名。

现在,我们可以开始处理文件上传逻辑。在 Flask 中,我们需要使用 request.files.get() 方法来获取上传的文件。该方法将返回一个 FileStorage 对象,可以使用它的 save() 方法将文件保存到服务器上。

from flask import Flask, request, render_template

app = Flask(__name__)

@app.route('/')
def index():
    return render_template('file_upload.html')

@app.route('/file_upload', methods=['POST'])
def file_upload():
    file = request.files.get('file')
    if file:
        file.save('uploads/' + file.filename)
        return '文件上传成功'
    else:
        return '上传失败,未选择文件'

if __name__ == '__main__':
    app.run()

在上面的代码中,我们使用了 index() 函数来渲染 HTML 表单。在文件上传时,接收到 POST 请求后将跳转到 file_upload() 函数进行处理。在 file_upload() 函数中,我们首先使用 request.files.get() 方法获取上传的文件,然后通过 save() 方法将文件保存到指定的文件夹中。

注意,这里的文件路径必须使用相对路径,因为 Flask 默认会将当前目录作为应用程序的根目录。

完整代码如下:

from flask import Flask, request, render_template

app = Flask(__name__)

@app.route('/')
def index():
    return render_template('file_upload.html')

@app.route('/file_upload', methods=['POST'])
def file_upload():
    file = request.files.get('file')
    if file:
        file.save('uploads/' + file.filename)
        return '文件上传成功'
    else:
        return '上传失败,未选择文件'

if __name__ == '__main__':
    app.run()

需要注意的是,上传的文件可能会带来安全风险。例如,可能会上传恶意文件或文件名包含恶意代码。因此,我们应该对上传的文件进行检查和处理,以确保安全性。

为了检查上传的文件类型,可以使用 FileStorage 类的 content_type 属性。要限制文件类型,请使用 allowed_extensions 列表。

ALLOWED_EXTENSIONS = {'txt', 'pdf', 'png', 'jpg', 'jpeg', 'gif'}

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

@app.route('/file_upload', methods=['POST'])
def file_upload():
    file = request.files.get('file')
    if file and allowed_file(file.filename):
        file.save('uploads/' + file.filename)
        return '文件上传成功'
    else:
        return '上传失败,文件类型不支持'

在上面的代码中,我们定义了 ALLOWED_EXTENSIONS 列表存储支持的文件类型扩展名。然后,我们定义了 allowed_file() 函数来检查上传的文件是否合法。该函数会检查文件名是否包含支持的扩展名。

如果文件类型合法,则将其保存到指定的文件夹中;否则,返回“文件类型不支持”的提示信息。

以上就是 Flask 文件上传的完整攻略。通过使用 request.files.get() 和 FileStorage 类的 save() 方法,可以轻松地实现文件上传功能。在后端处理上传的文件时,为了确保安全性,应该对文件类型进行检查和处理。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Flask 文件上传方法(详解版) - Python技术站

(2)
上一篇 2023年3月13日
下一篇 2023年3月13日

相关文章

  • Bootstrap图片轮播组件Carousel使用方法详解

    Bootstrap图片轮播组件Carousel使用方法详解 Bootstrap是一款目前非常流行的前端开发框架,其中的Carousel(图片轮播)组件可以用于网页展示轮播图或广告图等。接下来详细讲述如何使用Bootstrap中的Carousel组件,包含从起步到实现的完整攻略。 第一步:在HTML文件中引入Bootstrap 首先需要在HTML文件中引入Bo…

    css 2023年6月11日
    00
  • 锁链战记魔神袭来活动攻略

    锁链战记魔神袭来活动攻略 锁链战记魔神袭来活动需要玩家完成一系列任务,最终击败魔神。下面是完整攻略,包括任务、奖励和战斗技巧。 任务 任务1:收集10个魔法水晶 玩家需要收集10个魔法水晶,可以通过各种方式获得。首先,可以通关任意关卡获得水晶碎片,10个碎片可以合成一个魔法水晶。其次,可以参加活动期间的限定商店购买水晶。最后,可以通过登录奖励或完成每日任务等…

    css 2023年6月10日
    00
  • [项目布局配置]Nosql与PythonWeb-Flask框架组合

    我来为你详细讲解”项目布局配置:Nosql与PythonWeb-Flask框架组合”的完整攻略。 1. 项目布局配置 在开始项目布局配置之前,需要先确保你已经成功安装Python和Flask框架。项目布局的规划非常重要,下面是一个简单的布局规划: MyWebProject/ ├── app/ │ ├── static/ │ └── templates/ ├─…

    Flask 2023年5月16日
    00
  • 详解flask入门模板引擎

    下面我将为您详细讲解“详解Flask入门模板引擎”的完整攻略。 什么是Flask模板引擎? Flask模板引擎是使用Flask框架来构建网站时,用来呈现动态HTML页面的工具。它允许开发者使用HTML,CSS,JavaScript等静态文件和模板语法结合生成动态页面。 如何在Flask中使用模板引擎? 首先我们需要安装Flask模板引擎,通过pip包管理器安…

    Flask 2023年5月15日
    00
  • Python使用Flask Migrate模块迁移数据库

    下面我将详细讲解如何在Python中使用Flask Migrate模块迁移数据库的完整攻略。 准备工作 使用Flask Migrate模块迁移数据库前,需要确认已安装以下组件: Flask Flask Migrate Flask Script SQLAlchemy 如果未安装以上组件,可以使用以下命令进行安装: pip install flask flask…

    Flask 2023年5月16日
    00
  • Dreamweaver网页中的文本怎么添加背景图片?

    添加背景图片是网页制作中常用的技巧之一,而使用Dreamweaver这样的编辑器,可以更加方便地实现这一效果。下面是添加背景图片的完整攻略: 步骤一:选择需要添加背景图片的元素 在Dreamweaver中,我们可以通过选择需要添加背景图片的元素,来设置该元素的背景图片。可以选择页面中任何元素作为背景图片的载体,比如body、div或者p等标签。根据需要,选择…

    css 2023年6月9日
    00
  • CSS实例:创建一个鼠标感应换图片的按钮

    下面我将详细讲解如何使用CSS创建一个鼠标感应换图片的按钮。 1. 创建HTML结构 首先,我们需要在HTML中创建一个基本的按钮结构。在这个例子中,我们使用button元素来创建按钮,它的class属性为button-change-img。 <button class="button-change-img"></but…

    css 2023年6月10日
    00
  • 设置背景色解决png图片设置background不显示问题

    设置背景色是解决 png 图片设置 background 不显示的一种有效方法。下面为您详细讲解如何设置背景色以解决此问题。 步骤一:选择合适的背景色 首先,我们需要选择一种合适的背景色。这需要根据 png 图片的具体情况而定。如果您的 png 图片背景颜色为白色,则可以使用 #fff 作为背景色;如果背景颜色为透明,则可以使用rgba(0,0,0,0)表示…

    css 2023年6月9日
    00
合作推广
合作推广
分享本页
返回顶部