- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章flask入门之文件上传与邮件发送示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
文件上传邮件发送 。
1、原生文件上传 。
form.html 。
1
2
3
4
5
|
<
img
src
=
"{{ url_for('static',filename='img/17.jpg') }}"
width
=
"300"
alt
=
""
>
<
form
action
=
""
method
=
"post"
enctype
=
"multipart/form-data"
>
<
p
>修改头像 <
input
type
=
"file"
name
=
"file"
></
p
>
<
p
><
input
type
=
"submit"
value
=
"提交"
></
p
>
</
form
>
|
manage.py 。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
#文件上传的视图函数
@app
.route(
'/upload/'
,methods
=
[
'GET'
,
'POST'
])
def
icon():
img_name
=
None
if
request.method
=
=
'POST'
and
'file'
in
request.files:
# return '有文件上传了'
file
=
request.files.get(
'file'
)
filename
=
file
.filename
#拿到文件名称
#图片上传保存的路径
imgPath
=
os.path.join(os.getcwd(),
'static/upload/'
+
filename)
file
.save(imgPath)
img_name
=
filename
return
render_template(
'user/change_icon.html'
,img_name
=
img_name)
|
使用wtf和bootstrap渲染文件上传 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
from
flask
import
Flask,render_template,request
from
flask_script
import
Manager
from
flask_wtf
import
FlaskForm
from
flask_wtf.
file
import
FileField,FileAllowed,FileRequired
from
wtforms
import
SubmitField
from
flask_uploads
import
UploadSet,patch_request_class,configure_uploads,IMAGES
from
flask_bootstrap
import
Bootstrap
import
os
from
PIL
import
Image
app
=
Flask(__name__)
app.config[
'MAX_CONTENT_LENGTH'
]
=
1024
*
1024
*
64
app.config[
'SECRET_KEY'
]
=
'abcdef'
app.config[
'UPLOADED_PHOTOS_DEST'
]
=
os.path.join(os.getcwd(),
'static/upload'
)
bootstrap
=
Bootstrap(app)
file
=
UploadSet(
'photos'
,IMAGES)
configure_uploads(app,
file
)
patch_request_class(app,size
=
None
)
manager
=
Manager(app)
#自定义一个文件上传的表单类
class
File
(FlaskForm):
photos
=
FileField(
'修改头像'
,validators
=
[FileRequired(message
=
'文件不能为空'
),FileAllowed(
file
,message
=
'该文件类型不允许上传'
)])
submit
=
SubmitField(
'提交'
)
@app
.route(
'/'
)
def
index():
return
render_template(
'index.html'
)
#生成随机的图片名称
def
random_name(suffix,length
=
32
):
import
string,random
myStr
=
string.ascii_letters
+
'0123456789'
return
''.join(random.choice(myStr)
for
i
in
range
(length))
+
suffix
@app
.route(
'/upload/'
,methods
=
[
'GET'
,
'POST'
])
def
icon():
form
=
File
()
img_url
=
None
if
form.validate_on_submit():
data
=
request.files.get(
'photos'
)
suffix
=
os.path.splitext(data.filename)[
-
1
]
newName
=
random_name(suffix)
file
.save(data,name
=
newName)
img_url
=
file
.url(newName)
img
=
Image.
open
(os.path.join(app.config[
'UPLOADED_PHOTOS_DEST'
],newName))
print
(img.size)
# 获取图片大小
# 设置尺寸
img.thumbnail((
128
,
128
))
# 当前缩放不是等比缩放 变成等比缩放
img.save(os.path.join(app.config[
'UPLOADED_PHOTOS_DEST'
],
's_'
+
newName))
return
render_template(
'user/wtf-uplods.html'
,form
=
form,img_url
=
img_url)
if
__name__
=
=
'__main__'
:
manager.run()
|
模板中的代码 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
from
flask
import
Flask,render_template,request
from
flask_script
import
Manager
from
flask_wtf
import
FlaskForm
from
flask_wtf.
file
import
FileField,FileAllowed,FileRequired
from
wtforms
import
SubmitField
from
flask_uploads
import
UploadSet,patch_request_class,configure_uploads,IMAGES
from
flask_bootstrap
import
Bootstrap
import
os
from
PIL
import
Image
app
=
Flask(__name__)
app.config[
'MAX_CONTENT_LENGTH'
]
=
1024
*
1024
*
64
app.config[
'SECRET_KEY'
]
=
'abcdef'
app.config[
'UPLOADED_PHOTOS_DEST'
]
=
os.path.join(os.getcwd(),
'static/upload'
)
bootstrap
=
Bootstrap(app)
file
=
UploadSet(
'photos'
,IMAGES)
configure_uploads(app,
file
)
patch_request_class(app,size
=
None
)
manager
=
Manager(app)
#自定义一个文件上传的表单类
class
File
(FlaskForm):
photos
=
FileField(
'修改头像'
,validators
=
[FileRequired(message
=
'文件不能为空'
),FileAllowed(
file
,message
=
'该文件类型不允许上传'
)])
submit
=
SubmitField(
'提交'
)
@app
.route(
'/'
)
def
index():
return
render_template(
'index.html'
)
#生成随机的图片名称
def
random_name(suffix,length
=
32
):
import
string,random
myStr
=
string.ascii_letters
+
'0123456789'
return
''.join(random.choice(myStr)
for
i
in
range
(length))
+
suffix
@app
.route(
'/upload/'
,methods
=
[
'GET'
,
'POST'
])
def
icon():
form
=
File
()
img_url
=
None
if
form.validate_on_submit():
data
=
request.files.get(
'photos'
)
suffix
=
os.path.splitext(data.filename)[
-
1
]
newName
=
random_name(suffix)
file
.save(data,name
=
newName)
img_url
=
file
.url(newName)
img
=
Image.
open
(os.path.join(app.config[
'UPLOADED_PHOTOS_DEST'
],newName))
print
(img.size)
# 获取图片大小
# 设置尺寸
img.thumbnail((
128
,
128
))
# 当前缩放不是等比缩放 变成等比缩放
img.save(os.path.join(app.config[
'UPLOADED_PHOTOS_DEST'
],
's_'
+
newName))
return
render_template(
'user/wtf-uplods.html'
,form
=
form,img_url
=
img_url)
if
__name__
=
=
'__main__'
:
manager.run()
|
2、发送邮件 flask-mail 。
1
|
pip install flask
-
mail
|
设置临时环境变量 。
windows set 名=值 。
Ubuntu下 export 名=值 。
注意: 名和值都不用加引号 。
单线程发送邮件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
from
flask
import
Flask,render_template
from
flask_script
import
Manager
from
flask_mail
import
Mail,Message
import
os
app
=
Flask(__name__)
app.config[
'MAIL_SERVER'
]
=
'smtp.163.com'
# 为了保密 将邮箱账号和授权码都加入到了临时环境变量中
app.config[
'MAIL_USERNAME'
]
=
os.environ.get(
'MAIL_USERNAME'
)
app.config[
'MAIL_PASSWORD'
]
=
os.environ.get(
'MAIL_PASSWORD'
)
mail
=
Mail(app)
manager
=
Manager(app)
@app
.route(
'/send_mail/'
)
def
send_mail():
msg
=
Message(subject
=
'大郎'
,recipients
=
[
'793390457@qq.com'
],sender
=
app.config[
'MAIL_USERNAME'
])
msg.html
=
render_template(
'email/activate.html'
,username
=
'大郎'
)
mail.send(message
=
msg)
return
'发送邮件'
if
__name__
=
=
'__main__'
:
manager.run()
|
异步发送邮件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
from
flask
import
Flask,render_template
from
flask_script
import
Manager
from
flask_mail
import
Mail,Message
import
os
from
threading
import
Thread
app
=
Flask(__name__)
app.config[
'MAIL_SERVER'
]
=
'smtp.163.com'
app.config[
'MAIL_USERNAME'
]
=
os.environ.get(
'MAIL_USERNAME'
)
app.config[
'MAIL_PASSWORD'
]
=
os.environ.get(
'MAIL_PASSWORD'
)
mail
=
Mail(app)
manager
=
Manager(app)
@app
.route(
'/send_mail/'
)
def
send_mail():
msg
=
Message(subject
=
'大郎'
,recipients
=
[
'793390457@qq.com'
],sender
=
app.config[
'MAIL_USERNAME'
])
msg.html
=
render_template(
'email/activate.html'
,username
=
'大郎'
)
thr
=
Thread(target
=
async_send_mail,args
=
(msg,))
#创建线程 参数1为创建子线程 参数2为传递参数 类型为元组
thr.start()
#开启线程
return
'发送邮件'
def
async_send_mail(msg):
#开启程序上下文 把当前请求 作为同一个请求
with app.app_context():
mail.send(message
=
msg)
if
__name__
=
=
'__main__'
:
manager.run()
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://segmentfault.com/a/1190000015240818 。
最后此篇关于flask入门之文件上传与邮件发送示例的文章就讲到这里了,如果你想了解更多关于flask入门之文件上传与邮件发送示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这个问题在这里已经有了答案: 关闭 11 年前。 Possible Duplicate: Sample data for IPv6? 除了 wireshark 在其网站上提供的内容之外,是否有可以下
我正在寻找可以集成到现有应用程序中并使用多拖放功能的示例或任何现成的解决方案。我在互联网上找到的大多数解决方案在将多个项目从 ListBox 等控件拖放到另一个 ListBox 时效果不佳。谁能指出我
我是 GATE Embedded 的新手,我尝试了简单的示例并得到了 NoClassDefFoundError。首先我会解释我尝试了什么 在 D:\project\gate-7.0 中下载并提取 Ga
是否有像 Eclipse 中的 SWT 示例那样的多合一 JFace 控件示例?搜索(在 stackoverflow.com 上使用谷歌搜索和搜索)对我没有帮助。 如果它是一个独立的应用程序或 ecl
我找不到任何可以清楚地解释如何通过 .net API(特别是 c#)使用谷歌计算引擎的内容。有没有人可以指点我什么? 附言我知道 API 引用 ( https://developers.google.
最近在做公司的一个项目时,客户需要我们定时获取他们矩阵系统的数据。在与客户进行对接时,提到他们的接口使用的目前不常用的BASIC 认证。天呢,它好不安全,容易被不法人监听,咋还在使用呀。但是没办法呀,
最近在做公司的一个项目时,客户需要我们定时获取他们矩阵系统的数据。在与客户进行对接时,提到他们的接口使用的目前不常用的BASIC 认证。天呢,它好不安全,容易被不法人监听,咋还在使用呀。但是没办法呀,
我正在尝试为我的应用程序设计配置文件格式并选择了 YAML。但是,这(显然)意味着我需要能够定义、解析和验证正确的 YAML 语法! 在配置文件中,必须有一个名为 widgets 的集合/序列。 .这
你能给我一个使用 pysmb 库连接到一些 samba 服务器的例子吗?我读过有类 smb.SMBConnection.SMBConnection(用户名、密码、my_name、remote_name
linux服务器默认通过22端口用ssh协议登录,这种不安全。今天想做限制,即允许部分来源ip连接服务器。 案例目标:通过iptables规则限制对linux服务器的登录。 处理方法:编
我一直在寻找任何 PostProjectAnalysisTask 工作代码示例,但没有看。 This页面指出 HipChat plugin使用这个钩子(Hook),但在我看来它仍然使用遗留的 Po
我发现了 GWT 的 CustomScrollPanel 以及如何自定义滚动条,但我找不到任何示例或如何设置它。是否有任何示例显示正在使用的自定义滚动条? 最佳答案 这是自定义 native 滚动条的
我正在尝试开发一个 Backbone Marionette 应用程序,我需要知道如何以最佳方式执行 CRUD(创建、读取、更新和销毁)操作。我找不到任何解释这一点的资源(仅适用于 Backbone)。
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 去年关闭。 Improve this
我需要一个提交多个单独请求的 django 表单,如果没有大量定制,我找不到如何做到这一点的示例。即,假设有一个汽车维修店使用的表格。该表格将列出商店能够进行的所有可能的维修,并且用户将选择他们想要进
我有一个 Multi-Tenancy 应用程序。然而,这个相同的应用程序有 liquibase。我需要在我的所有数据源中运行 liquibase,但是我不能使用这个 Bean。 我的应用程序.yml
我了解有关单元测试的一般思想,并已在系统中发生复杂交互的场景中使用它,但我仍然对所有这些原则结合在一起有疑问。 我们被警告不要测试框架或数据库。好的 UI 设计不适合非人工测试。 MVC 框架不包括一
我正在使用 docjure并且它的 select-columns 函数需要一个列映射。我想获取所有列而无需手动指定。 如何将以下内容生成为惰性无限向量序列 [:A :B :C :D :E ... :A
$condition使用说明和 $param在 findByAttributes在 Yii 在大多数情况下,这就是我使用 findByAttributes 的方式 Person::model()->f
我在 Ubuntu 11.10 上安装了 qtcreator sudo apt-get install qtcreator 安装的版本有:QT Creator 2.2.1、QT 4.7.3 当我启动
我是一名优秀的程序员,十分优秀!