Flask—04-文件上传与邮件发送(自带优化)
文件上传与邮件发送
可以按照标题分别直接粘贴对应的文件夹,运行直接用:
原生上传
模板文件
<form method="post" enctype="multipart/form-data">
<input type="file" name="photo" /><br />
<input type="submit" value="上传" />
</form>
视图函数
@app.route('/upload/', methods=['GET', 'POST'])
def upload():
if request.method == 'POST':
# 获取上传对象
photo = request.files.get('photo')
if photo:
# 保存上传文件,参数是文件保存的路径名
photo.save(photo.filename)
return '文件上传成功'
return '文件上传失败'
return render_template('upload.html')
优化完善
import os
from flask import send_from_directory # 上传文件保存位置
app.config['UPLOADED_FOLDER'] = os.path.join(os.getcwd(), 'static/upload')
# 请求大小(文件大小限制)
app.config['MAX_CONTENT_LENGTH'] = 1024 * 1024 * 8 # 判断是否是允许的文件类型
def allowed_file(filename):
return '.' in filename and filename.rsplit('.', 1)[1] in ALLOWED_SUFFIX # 展示上传的文件
@app.route('/uploaded/<filename>')
def upladed(filename):
# 安全的发送文件
return send_from_directory(app.config['UPLOADED_FOLDER'], filename) @app.route('/upload/', methods=['GET', 'POST'])
def upload():
img_url = None
if request.method == 'POST':
# 获取上传对象
photo = request.files.get('photo')
# 保存前验证文件的类型
if photo and allowed_file(photo.filename):
# 拼接文件保存的完整路径名
pathname = os.path.join(app.config['UPLOADED_FOLDER'],
photo.filename)
# 保存上传文件,参数是文件保存的路径名
photo.save(pathname)
img_url = url_for('upladed', filename=photo.filename)
return render_template('upload.html', img_url=img_url)
优化:大小限定、类型限定、保存位置、查看上传文件
flask-uploads
说明:极大地优化了文件上传的操作,使用非常方便
安装:
pip install flask-uploads
使用:
- 配置
from flask_uploads import UploadSet, IMAGES
from flask_uploads import configure_uploads
from flask_uploads import patch_request_class
import os app = Flask(__name__)
# 设置文件的大小:8M=8*1024*1024k
app.config['MAX_CONTENT_LENGTH'] = 1024 * 1024 * 8
app.config['UPLOADED_PHOTOS_DEST'] = os.path.join(os.getcwd(), 'static/upload')
# 创建上传对象,指定名字和上传文件的类型
photos = UploadSet('photos', IMAGES)
# 配置上传对象
configure_uploads(app, photos)
# 设置上传文件大小,默认64M,设置为None,大小由MAX_CONTENT_LENGTH决定
patch_request_class(app, size=None)
- 视图函数
@app.route('/upload/', methods=['GET', 'POST'])
def upload():
img_url = None
if request.method == 'POST':
# 获取上传对象
photo = request.files.get('photo')
if photo:
# 保存上传文件
photos.save(photo)
# 获取上传文件的地址
img_url = photos.url(photo.filename)
return render_template('upload.html', img_url=img_url)
- 优化上传:生成随机文件名,生成缩略图(PIL模块,只支持py2,py3中使用需要安装pillow)
# 生成随机字符串
def random_string(length=32):
import random
base_str = 'abcdefghijklmnopqrstuvwxyz1234567890'
return ''.join(random.choice(base_str) for i in range(length)) @app.route('/upload/', methods=['GET', 'POST'])
def upload():
img_url = None
if request.method == 'POST':
# 获取上传对象
photo = request.files.get('photo')
if photo:
# 提取文件后缀
suffix = os.path.splitext(photo.filename)[1]
# 生成随机文件名
filename = random_string() + suffix
# 保存上传文件
photos.save(photo, name=filename)
# 生成缩略图
from PIL import Image
# 拼接完整路径名
pathname = os.path.join(app.config['UPLOADED_PHOTOS_DEST'], filename)
# 打开文件
img = Image.open(pathname)
# 设置大小
img.thumbnail((64, 64))
# 保存修改后的图片
img.save(pathname)
# 获取上传文件的地址
img_url = photos.url(filename)
return render_template('upload.html', img_url=img_url)
综合使用
- 要求:结合
flask-bootstrap、flask-wtf、flask-uploads
等实现文件上传 - 使用:
- 各种配置及对象创建
- 注意对象创建的先后顺序
- 上传文件的校验处理过程与上面一样
flask-mail
说明:专门用来实现邮件发送的扩展库,使用非常方便。
安装:
pip install flask-mail
使用:
from flask_mail import Mail, Message
import os # 邮件配置,一定要放在对象创建之前
# 邮箱服务器:不同类型邮箱服务器不同,不知道的请百度
app.config['MAIL_SERVER'] = 'smtp.xxx.com'
# 用户名
app.config['MAIL_USERNAME'] = 'xxx@xxx.com'
# 密码:如果密码添加到了环境变量可以直接引用'MAIL_PASSWORD',否则直接把'123456'换成自己的邮箱密码。
app.config['MAIL_PASSWORD'] = os.getenv('MAIL_PASSWORD', '123456') # 创建发送邮件的对象
mail = Mail(app) @app.route('/send/')
def send():
# 创建邮件消息对象
msg = Message('账户激活',
recipients=['xxx@qq.com'],
sender=app.config['MAIL_USERNAME'])
# 设置邮件内容
msg.html = '恭喜你,中奖了!'
# 发送邮件
mail.send(msg)
return '邮件发送成功'
总结:
- 书写邮箱相关配置
- 创建发送邮件的(Mail)对象
- 创建邮件消息(Message)对象
- 使用mail的send方法发送邮件
封装函数发送邮件
# 封装函数发送邮件
def send_mail(subject, to, template, **kwargs):
# 处理邮件接收者
if isinstance(to, list):
recipients = to
elif isinstance(to, str):
recipients = to.split(',')
else:
raise Exception('邮件接收者参数有误')
# 创建邮件消息对象
msg = Message(subject=subject, recipients=recipients,
sender=app.config['MAIL_USERNAME'])
# 设置邮件内容
msg.html = render_template(template, **kwargs)
# 发送邮件
mail.send(msg) @app.route('/send/')
def send():
# 调用函数即可发送邮件
send_mail('账户激活', 'xxx@qq.com', 'activate.html', name='八戒')
return '邮件发送成功'
异步发送邮件
from flask import current_app
from threading import Thread # 异步发送邮件
def async_send_mail(app, msg):
# 邮件发送必须在程序上下文中进行
# 新的线程没有上下文,因此需要手动创建上下文
with app.app_context():
mail.send(msg) # 封装函数发送邮件
def send_mail(subject, to, template, **kwargs):
# 处理邮件接收者
if isinstance(to, list):
recipients = to
elif isinstance(to, str):
recipients = to.split(',')
else:
raise Exception('邮件接收者参数有误')
# 从代理中获取原始对象
app = current_app._get_current_object()
# 创建邮件消息对象
msg = Message(subject=subject,recipients=recipients,sender=app.config['MAIL_USERNAME'])
# 设置邮件内容
msg.html = render_template(template, **kwargs)
# 发送邮件:同步发送,会阻塞运行
# mail.send(msg)
# 创建一个线程,在新的线程中发送邮件
thr = Thread(target=async_send_mail, args=(app, msg))
# 启动线程
thr.start()
# 返回线程
return thr
QQ邮箱发送配置
# 密码,QQ邮箱需要使用授权码
app.config['MAIL_PASSWORD'] = os.getenv('MAIL_PASSWORD', '123456')
# QQ邮箱配置
# app.config['MAIL_PORT'] = 465
# 加密传输
# app.config['MAIL_USE_SSL'] = True
Flask—04-文件上传与邮件发送(自带优化)的更多相关文章
- SpringBoot项目实现文件上传和邮件发送
前言 本篇文章主要介绍的是SpringBoot项目实现文件上传和邮件发送的功能. SpringBoot 文件上传 说明:如果想直接获取工程那么可以直接跳到底部,通过链接下载工程代码. 开发准备 环境要 ...
- Silverlight 2中实现文件上传和电子邮件发送
Silverlight 2中实现文件上传和电子邮件发送 [收藏此页] [打印] 作者:IT168 TerryLee 2008-05-30 内容导航: 使用Web Service上传文件 [I ...
- Javaweb-文件上传和邮件发送
1.文件上传 新建空项目 准备工作 在maven仓库里下载commons io 和 commons fileupload两个jar包 实用类介绍 文件上传注意事项 为保证服务器安全,上传文件应该放在外 ...
- flask完成文件上传功能
在使用flask定义路由完成文件上传时,定义upload视图函数 from flask import Flask, render_template from werkzeug.utils import ...
- Flask入门文件上传flask-uploads(八)
1 视图传递多个参数 (1) 普通传参 : 关键字参数传递 return render_template('模板名称.html',arg1=val1,arg2=val2...) (2) 字典传参 : ...
- Spring Boot—04文件上传
package com.smartmap.sample.ch1.controller.view; import java.io.File; import java.io.IOException; im ...
- AJAX文件上传实践与分析,带HTML5文件上传API。
对于HTML5已经支持AJAX文件上传了,但如果需要兼容的话还是得用一点小技巧的,HTML5等等介绍,先来看看以前我们是怎么写的. 网上可能会有一些叫AJAX文件上传插件,但在AJAX2.0之前是不可 ...
- flask的文件上传和下载
http://flask.pocoo.org/docs/1.0/api/ http://docs.jinkan.org/docs/flask/api.html?highlight=download h ...
- Flask插件wtforms、Flask文件上传和Echarts柱状图
一.wtforms 类比Django的Form组件Form组件的主要应用是帮助我们自动生成HTML代码和做一些表单数据的验证 flask的wtforms用法跟Form组件大同小异参考文章:https: ...
随机推荐
- js面向对象3
1.this的使用 核心:在js中,this表示当前对象,“谁”调用了当前函数,“this”就指向了“谁” 语法: Function 类(){ this.属性=值; } 例1.在构造器中,使用this ...
- [转]jQuery Validate使用说明
本文转自:http://www.cnblogs.com/gimin/p/4757064.html jQuery Validate 导入 js 库 <script src="./jque ...
- C#中的MD5加密
1 using System.Web.Security; 2 string pswd = FormsAuthentication.HashPasswordForStoringInConfigFile ...
- 03.枚举和string以及int类型之间的转换
练习1: 将枚举类型强转成int类型 namespace _04.枚举类型的练习01 { //声明一个QQState类型的枚举 public enum QQState { OnLine, OffL ...
- express 请求跨域后端解决方法CORS
CORS全称Cross-Origin Resource Sharing,是HTML5规范定义的如何跨域访问资源. Origin表示本域,也就是浏览器当前页面的域.当JavaScript向外域(如sin ...
- javascript统计一个字符在一段字符串出现次数
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8" ...
- Netty-EventLoop
1. public interface EventLoop extends EventExecutor, EventLoopGroup 2. public interface EventExecuto ...
- 15_volatile
[volatile概念] volatile关键字的主要作用是是变量在多个线程间可见. [注意] 在java中,每一个线程都会有一块工作内存区,其中存放着所有线程共享的主内存中的变量的拷贝.当线程执行时 ...
- python 按值排序
转自:http://www.cnpythoner.com/post/266.html,感谢分享! python 字典(dict)的特点就是无序的,按照键(key)来提取相应值(value),如果我们需 ...
- SQL还原数据库后孤立用户问题处理(SQL 数据库 拥有对象 无法删除)
所谓孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录 孤立帐户的产生一般是一下两种: ...