FLASK 上传文件

HTML

form enctype="multipart/form-data"

编码类型 说明
application/x-www-form-urlencoded 表单数据编码为名称/值对。 这是标准编码格式。
multipart/form-data 表单数据编码为消息,页面上每个控件都有单独的部分。
text/plain 表单数据以纯文本编码,没有任何控件或格式字符。

form action = url地址

html 复制代码
<form action="/upload" method="post" enctype="multipart/form-data">

本来action属性是<form>元素的一个重要属性,它定义了当表单被提交时,表单数据应该发送到哪里(即哪个URL)。这个URL指向的服务器上的资源将负责处理这些提交的数据。

这里可以理解为绑定了后端函数,因为该地址规定了处理函数:

python 复制代码
@app.route('/upload', methods=['POST'])
def upload():

FLASK

后端声明

python 复制代码
import os
from flask import Flask, render_template, request, send_from_directory, redirect, url_for
from werkzeug.utils import secure_filename

app = Flask(__name__)
UPLOAD_FOLDER = 'static/uploads'
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
# 确保目录存在
os.makedirs(UPLOAD_FOLDER, exist_ok=True)

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

@app.route('/upload', methods=['POST'])
def upload():
    if 'file' not in request.files:
        return redirect(request.url)
    file = request.files['file']
    if file.filename == '':
        return redirect(request.url)
    if file:
        filename = secure_filename(file.filename)
        file_path = os.path.join(app.config['UPLOAD_FOLDER'], filename)
        file.save(file_path)

        return render_template('index.html', original=filename)

附录

<p>定义一个段落。

<hr>代表章节、文章或其他长内容中段落之间的分隔符。

<pre>代表其内容已经预先排版过,格式应当保留 。

<blockquote>代表引用自其他来源的内容。

<ol>定义一个有序列表。

<ul>定义一个无序列表。

<li>定义列表中的一个列表项。

<dl>定义一个定义列表(一系列术语和其定义)。

<dt>代表一个由下一个<dd>定义的术语。

<dd>代表出现在它之前术语的定义。

<figure>代表一个和文档有关的图例。

<figcaption>代表一个图例的说明。

<div>代表一个通用的容器,没有特殊含义。

相关推荐
John Song15 分钟前
Python创建虚拟环境的方式对比与区别?
开发语言·python
geovindu17 分钟前
python: Bridge Pattern
python·设计模式·桥接模式
搞程序的心海18 分钟前
Python面试题(一):5个最常见的Python基础问题
开发语言·python
宝贝儿好3 小时前
【强化学习实战】第十一章:Gymnasium库的介绍和使用(1)、出租车游戏代码详解(Sarsa & Q learning)
人工智能·python·深度学习·算法·游戏·机器学习
程序媛一枚~6 小时前
✨✨✨使用Python,OpenCV及图片拼接生成❤️LOVE❤️字样图,每张小图加随机颜色边框,大图加随机大小随机颜色边框
图像处理·python·opencv·numpy·图像拼接
MediaTea7 小时前
Python:collections.Counter 常用函数及应用
开发语言·python
如若1237 小时前
flash-attn 安装失败?从报错到成功的完整排雷指南(CUDA 12.8 + PyTorch 2.7)
人工智能·pytorch·python
007张三丰7 小时前
知乎高赞回答爬虫:从零开始,建立你的专属知识库
爬虫·python·知识库·python爬虫·知乎·高赞回答
李昊哲小课7 小时前
Python json模块完整教程
开发语言·python·json
易醒是好梦7 小时前
Python flask demo
开发语言·python·flask