flask入門之文件上傳與郵件發(fā)送示例
文件上傳郵件發(fā)送
一、原生文件上傳
form.html
<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
#文件上傳的視圖函數(shù) @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渲染文件上傳
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) #自定義一個(gè)文件上傳的表單類 class File(FlaskForm): photos = FileField('修改頭像',validators=[FileRequired(message='文件不能為空'),FileAllowed(file,message='該文件類型不允許上傳')]) submit = SubmitField('提交') @app.route('/') def index(): return render_template('index.html') #生成隨機(jī)的圖片名稱 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) # 獲取圖片大小 # 設(shè)置尺寸 img.thumbnail((128, 128)) # 當(dāng)前縮放不是等比縮放 變成等比縮放 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()
模板中的代碼
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) #自定義一個(gè)文件上傳的表單類 class File(FlaskForm): photos = FileField('修改頭像',validators=[FileRequired(message='文件不能為空'),FileAllowed(file,message='該文件類型不允許上傳')]) submit = SubmitField('提交') @app.route('/') def index(): return render_template('index.html') #生成隨機(jī)的圖片名稱 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) # 獲取圖片大小 # 設(shè)置尺寸 img.thumbnail((128, 128)) # 當(dāng)前縮放不是等比縮放 變成等比縮放 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()
二、發(fā)送郵件 flask-mail
pip install flask-mail
設(shè)置臨時(shí)環(huán)境變量
windows set 名=值
Ubuntu下 export 名=值
注意: 名和值都不用加引號(hào)
單線程發(fā)送郵件
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' # 為了保密 將郵箱賬號(hào)和授權(quán)碼都加入到了臨時(shí)環(huán)境變量中 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 '發(fā)送郵件' if __name__ == '__main__': manager.run()
異步發(fā)送郵件
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,)) #創(chuàng)建線程 參數(shù)1為創(chuàng)建子線程 參數(shù)2為傳遞參數(shù) 類型為元組 thr.start() #開啟線程 return '發(fā)送郵件' def async_send_mail(msg): #開啟程序上下文 把當(dāng)前請求 作為同一個(gè)請求 with app.app_context(): mail.send(message=msg) if __name__ == '__main__': manager.run()
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
opencv 形態(tài)學(xué)變換(開運(yùn)算,閉運(yùn)算,梯度運(yùn)算)
這篇文章主要介紹了opencv 形態(tài)學(xué)變換(開運(yùn)算,閉運(yùn)算,梯度運(yùn)算),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07用Python編寫簡單的gRPC服務(wù)的詳細(xì)過程
gRPC 是可以在任何環(huán)境中運(yùn)行的現(xiàn)代開源高性能 RPC 框架。接下來通過本文給大家介紹用Python編寫簡單的gRPC服務(wù)的詳細(xì)過程,感興趣的朋友一起看看吧2021-07-07Python自動(dòng)化辦公之郵件發(fā)送全過程詳解
這篇文章主要介紹了Python自動(dòng)化辦公之郵件發(fā)送全過程詳解,使用Python實(shí)現(xiàn)自動(dòng)化郵件發(fā)送,可以讓你擺脫繁瑣的重復(fù)性業(yè)務(wù),可以節(jié)省非常多的時(shí),下面我們就來看看具體的操作配置吧2022-01-01Python+django實(shí)現(xiàn)文件上傳
本系列以可操作性為主,介紹如何通過django web框架來實(shí)現(xiàn)一些簡單的功能。每一篇文章都具有完整性和獨(dú)立性。使用新手在動(dòng)手做的過程中體會(huì)web開發(fā)的過程,過程中細(xì)節(jié)請參考相關(guān)文檔。2016-01-01Python實(shí)現(xiàn)利用163郵箱遠(yuǎn)程關(guān)電腦腳本
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)利用163郵箱遠(yuǎn)程關(guān)電腦腳本,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02python中隨機(jī)函數(shù)random用法實(shí)例
這篇文章主要介紹了python中隨機(jī)函數(shù)random用法,實(shí)例分析了random函數(shù)的相關(guān)使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04Python中字符串列表的相互轉(zhuǎn)換實(shí)際應(yīng)用場景
在Python編程中,經(jīng)常會(huì)遇到需要將字符串列表相互轉(zhuǎn)換的情況,這涉及到將逗號(hào)分隔的字符串轉(zhuǎn)換為列表,或者將列表中的元素連接成一個(gè)字符串,本文將深入討論這些情景,并提供豐富的示例代碼,幫助讀者更全面地理解字符串列表的轉(zhuǎn)換操作2023-12-12