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>代表一个通用的容器,没有特殊含义。

相关推荐
徐赛俊18 分钟前
# 自动定时运行Python爬虫脚本教程(Windows任务计划程序)
windows·爬虫·python
程序员秘密基地1 小时前
基于html,css,jquery,django,lstm,cnn,tensorflow,bert,推荐算法,mysql数据库
python·cnn·tensorflow·lstm·推荐算法
技术炼丹人1 小时前
从RNN为什么长依赖遗忘到注意力机制的解决方案以及并行
人工智能·python·算法
hqxstudying2 小时前
Java开发时出现的问题---语言特性与基础机制陷阱
java·jvm·python
仪器科学与传感技术博士2 小时前
python:机器学习中的分类与回归怎么理解
python·机器学习·分类
CodeCraft Studio2 小时前
使用 Aspose.OCR 将图像文本转换为可编辑文本
java·人工智能·python·ocr·.net·aspose·ocr工具
allenXer2 小时前
Flask全栈入门:打造区块链艺术品交易所
python·flask·区块链
2202_756749693 小时前
06 基于sklearn的机械学习-欠拟合、过拟合、正则化、逻辑回归
人工智能·python·深度学习·机器学习·计算机视觉·逻辑回归·sklearn
赵英英俊3 小时前
Python day34
人工智能·python·深度学习
七七软件开发3 小时前
直播 app 系统架构分析
java·python·小程序·系统架构·php