Flask上传文件
回顾知识点
form表单中,一旦涉及到上传文件就要就必须要有 enctype属性,而且必须等于 multipart/form-data.而且提交方式为‘post’, method = 'post'
步骤
- 首先给form表单添加enctype属性和method属性
- enctype = 'multipart/form-data'
method = 'post'
- enctype = 'multipart/form-data'
- 在项目的根目录中创建文件保存路径。
- 指定文件的保存路径
- # os.path.dirname(__file__)获取的是app.py文件的路径,也就是在项目根目录中,然后把它放在images文件夹中
UPLOAD_PATH = os.path.join(os.path.dirname(__file__),'images')
- # os.path.dirname(__file__)获取的是app.py文件的路径,也就是在项目根目录中,然后把它放在images文件夹中
- if..else两种情况当页面访问为get方式直接跳转,post方式进行操作
- 后台要获取上传的文件,用request.files.get('文件名')来获取
- 保存文件之前,使用werkzeug.utils.secure_filename来对上传上来的文件名进行一个过滤。保证不会有安全问题。
- 获取到上传上来的文件后,使用
文件对象.save(路径)
方法来保存文件。路径=完整路径=路径名+文件名
代码实现
html代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>上传文件</title>
</head>
<body>
{# 但凡form中涉及到了上传文件,那么method = 'post' 和 enctype = 'multipart/form-data'#}
{# 当没有指定提交路劲时,默认向当前页面提交#}
<form action="" method="post" enctype="multipart/form-data">
<table>
<tr>
<td>头像:</td>
<td><input type="file" name="pichead"></td>
</tr>
<tr>
<td>心情:</td>
<td><input type="text" name="desc"></td>
</tr>
<tr>
<td></td>
<td><input type="submit" value="提交"></td>
</tr>
</table>
</form>
</body>
</html>
Py代码
# 上传文件优化,文件名安全的意思
from werkzeug.utils import secure_filename
# os.path.dirname(__file__)获取的是app.py文件的路径,也就是在项目根目录中,然后把它放在images文件夹中
UPLOAD_PATH = os.path.join(os.path.dirname(__file__),'images')
# Flask上传文件的实现
@app.route('/upload/',methods=['POST','GET'])
def upload():
if request.method == 'GET':
return render_template('upload.html')
else:
desc = request.form.get('desc')
# 获取pichead文件对象
pichead = request.files.get('pichead')
print(desc)
# 保存到服务器
# save方法传完整的路径和文件名
# pichead.save(os.path.join(UPLOAD_PATH,pichead.filename))
# 上行可以进行优化,下行是对pichead文件名进行包装,保证文件名更安全。
filename = secure_filename(pichead.filename)
pichead.save(os.path.join(UPLOAD_PATH,filename))
return '文件上传成功
访问上传成功的文件
原理
从服务器中读取,应该定义一个url与视图函数,来获取指定的文件。
在视图函数中,使用send_from_directory(文件目录,文件名)来获取。
实现
# 访问已经上传号的服务器上的文件,要借助flask中的send_from_directory函数
from flask import send_from_directory
# 访问服务器上的文件(已经上传成功的文件)
@app.route('/images/<filename>')
def get_image(filename):
return send_from_directory(UPLOAD_PATH,filename)
利用flask-wtf验证上传文件
原理
借用wtforms和flask_wt内的函数,验证文件
关键之处
- 对文件类型字段的验证,需要采用wtforms中的FileField这个类型
- 验证器需要从flask_wtf.file中导入,flask_wtf.file.FileRequired和flask_wtf.file.FileAllowed类型
- FileRequired是用来验证文件上传不能为空。<