【Python】Web学习笔记_flask(3)——上传文件

用GET、POST请求上传图片并呈现出来

首先还是创建文件上传的模板

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>上传图片</title>
</head>
<body>
<form action="" method="post" enctype="multipart/form-data">
    <div>
        <label for="avatar">上传图片</label>
        <input type="file" id="avatar" name="avatar" value="">
    </div>
    <button type="submit">提交</button>
</form>

</body>
</html>

然后需要定义几个函数:

upload():路由函数,接收GET请求时,显示模板文件内容,接收post请求时,上传图片

allowed_file():检测上传的文件是否满足设置的类型

random_file():为上传的文件重新创建随机的不重复文件名

uploaded_file():显示图片内容

python 复制代码
import os.path
import uuid
import config

from flask import Flask,url_for,redirect,request,render_template,send_from_directory

ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'gif','PNG', 'JPG', 'JPEG', 'GIF',}

app=Flask(__name__)
UPLOAD_FOLDER = os.path.join(app.root_path,'uploads')
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
@app.route('/upload',methods=['GET','POST'])
#创建路由函数,接收GET请求时,显示模板文件内容,接收post请求时,上传图片
def upload():
    """
    #头像上传表单页面
    :return:
    """
    if request.method=='POST':
        #接受头像字段
        avatar=request.files['avatar']
        #判断头像是否上传
        if avatar and allowed_file(avatar.filename):
            filename=random_file(avatar.filename)
            avatar.save(os.path.join(app.config['UPLOAD_FOLDER'],filename))
            return redirect(url_for('uploaded_file',filename=filename))
    return render_template('upload.html')

def allowed_file(filename):
    """
    #判断上传文件类型是否允许
    :param filename 文件名
    :return: 布尔值 TRUE or False
    """
    print(filename)
    return '.' in filename and filename.rsplit('.',1)[1] in ALLOWED_EXTENSIONS

def random_file(filename):
    """
    生成随机文件名
    :param filename: 文件名
    :return:随机文件名
    """
    ext=os.path.splitext(filename)[1]
    #使用uuid生成随机字符
    new_filename=uuid.uuid4().hex+ext
    return new_filename

@app.route('/uploads/<filename>')
def uploaded_file(filename):
    """
    显示上传头像
    :param filename:文件名
    :return: 真实文件路径
    """
    return send_from_directory(app.config['UPLOAD_FOLDER'],filename)


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

需要单独设置的内容:

ALLOWED_EXTENSIONS:文件后缀类型

UPLOAD_FOLDER:上传文件的路径,如果不设置,会报错:

KeyError: 'UPLOAD_FOLDER'

python 复制代码
ALLOWED_EXTENSIONS = {'png', 'jpg', 'jpeg', 'gif','PNG', 'JPG', 'JPEG', 'GIF',}

UPLOAD_FOLDER = os.path.join(app.root_path,'uploads')
app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER

相关推荐
在路上`2 小时前
前端学习之后端java小白(四)之数据库设计
sql·学习
BillKu2 小时前
Vue3 + Element-Plus 抽屉关闭按钮居中
前端·javascript·vue.js
面向星辰3 小时前
html中css的四种定位方式
前端·css·html
Async Cipher3 小时前
CSS 权重(优先级规则)
前端·css
大怪v3 小时前
前端佬:机器学习?我也会啊!😎😎😎手“摸”手教你做个”自动驾驶“~
前端·javascript·机器学习
☼←安于亥时→❦3 小时前
PyTorch 梯度与微积分
人工智能·pytorch·python
Liquad Li4 小时前
Angular 面试题及详细答案
前端·angular·angular.js
程序员三藏4 小时前
2025最新的软件测试面试八股文(800+道题)
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
用户21411832636024 小时前
首发!即梦 4.0 接口开发全攻略:AI 辅助零代码实现,开源 + Docker 部署,小白也能上手
前端
Pocker_Spades_A4 小时前
Python快速入门专业版(二十三):for循环基础:遍历字符串、列表与range()函数(计数案例)
python