摘要:文件上傳郵件發(fā)送一原生文件上傳修改頭像提交文件上傳的視圖函數(shù)有文件上傳了拿到文件名稱圖片上傳保存的路徑使用和渲染文件上傳自定義一個文件上傳的表單類修改頭像文件不能為空該文件類型不允許上傳提交生成隨機的圖片名稱獲取圖片大小設(shè)置尺寸當前縮放
文件上傳郵件發(fā)送 一、原生文件上傳 form.html
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) #自定義一個文件上傳的表單類 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) # 獲取圖片大小 # 設(shè)置尺寸 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()模板中的代碼
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) # 獲取圖片大小 # 設(shè)置尺寸 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()二、發(fā)送郵件 flask-mail
pip install flask-mail
設(shè)置臨時環(huán)境變量windows set 名=值
Ubuntu下 export 名=值
注意: 名和值都不用加引號
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" # 為了保密 將郵箱賬號和授權(quán)碼都加入到了臨時環(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): #開啟程序上下文 把當前請求 作為同一個請求 with app.app_context(): mail.send(message=msg) if __name__ == "__main__": manager.run()
flask入門5-model
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/41834.html
摘要:表單一原生表單原生表單用戶名請輸入用戶名密碼請輸入密碼提交接收表單的數(shù)據(jù)提交過來了將倆個路由地址合并為同一個二使用表單擴展庫作用是一個用于表單處理的擴展庫提供表單的校驗的功能使用字段類型字段名稱字段類型普通文本字段密碼框提交按鈕多行文本 flask 表單 一、原生表單 form.html {% extends common/base.html %} {% block title %} ...
摘要:每天的內(nèi)容跑起來模板引擎表單文件上傳郵件發(fā)送一框架的簡介模型負責數(shù)據(jù)的操作視圖負責數(shù)據(jù)的展示控制器控制你的的操作以及視圖模板的渲染在中叫做模型負責數(shù)據(jù)的操作控制你的的操作以及視圖模板的渲染業(yè)務(wù)邏輯的操作模板負責數(shù)據(jù)的展示二架構(gòu)三概念是 flask 每天的內(nèi)容 flask跑起來 模板引擎 flask表單 文件上傳郵件發(fā)送 flask-sqlalchemy 一、web框架的簡介 M ...
摘要:帶附件的郵件有時候,我們發(fā)郵件的時候需要添加附件,比如文檔和圖片等,這也很簡單,代碼如下郵件服務(wù)器地址郵件服務(wù)器端口啟用上面的代碼中,我們通過打開了本機的某張圖片,然后通過方法將附件內(nèi)容添加到對象。 前往本文博客 簡介 給用戶發(fā)送郵件是 Web 應(yīng)用中最常見的任務(wù)之一,比如用戶注冊,找回密碼等。Python 內(nèi)置了一個 smtplib 的模塊,可以用來發(fā)送郵件,這里我們使用 Flask...
摘要:函數(shù)攜帶目的地址主題郵件體模板和一組關(guān)鍵字參數(shù)。許多擴展操作是在假設(shè)有活動的應(yīng)用程序和請求上下文的情況下進行的。但是當函數(shù)在一個不同的線程上執(zhí)行,應(yīng)用程序上下文需要人為地創(chuàng)建使用。例如,執(zhí)行函數(shù)可以將郵件發(fā)送到的任務(wù)隊列中。 許多類型的應(yīng)用程序都會在某些事件發(fā)生的時候通知用戶,常用的溝通方法就是電子郵件。盡管在Flask應(yīng)用程序中,可以使用Python標準庫中的smtplib包來發(fā)送電...
摘要:為什么要使用發(fā)送郵件因為自帶的包比較底層,使用起來比較麻煩。發(fā)送模板郵件歡迎你觀看此文章,您的郵箱賬號為這個程序在上述文件上進行編寫給你發(fā)郵件啦還可以發(fā)送附件 為什么要使用flask-mail發(fā)送郵件? 因為python自帶的email包比較底層,使用起來比較麻煩。安裝Flask-Mail: pip install flask-mail 配置 Flask-Mail MAIL_SER...
閱讀 1266·2021-10-14 09:50
閱讀 1567·2019-08-30 15:54
閱讀 1023·2019-08-30 11:22
閱讀 2916·2019-08-30 10:50
閱讀 1801·2019-08-29 18:39
閱讀 3050·2019-08-29 13:07
閱讀 2079·2019-08-28 17:54
閱讀 751·2019-08-26 17:44