bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

flask-uploads擴展的使用-創新互聯

參考:
http://www.cnblogs.com/himir/p/5940705.html
https://zhuanlan.zhihu.com/p/24423891
flask-uploads    flask的一個文件上傳擴展, 提供了UploadSet這個概念    
flask-wtf(中文)    很強大的表單的擴展    
flask-bootstrap    bootstrap的flask擴展, 結合模版使用, 此處用到quick_form功能    
 
from flask import Flask, render_templatefrom flask_uploads import UploadSet, IMAGES, configure_uploadsfrom flask_wtf import Formfrom wtforms import SubmitFieldfrom flask_wtf.file import FileField, FileAllowed, FileRequiredfrom flask_bootstrap import Bootstrap
from werkzeug.utils import secure_filenameapp = Flask(__name__)# 新建一個set用于設置文件類型、過濾等set_mypic = UploadSet('mypic')  # mypic# 用于wtf.quick_form()模版渲染bootstrap = Bootstrap(app)# mypic 的存儲位置,
# UPLOADED_xxxxx_DEST, xxxxx部分就是定義的set的名稱, mypi, 下同app.config['UPLOADED_MYPIC_DEST'] = './static/img'# mypic 允許存儲的類型, IMAGES為預設的 tuple('jpg jpe jpeg png gif svg bmp'.split())
#DOCUMENTS = tuple('rtf odf ods gnumeric abw doc docx xls xlsx'.split())
#AUDIO = tuple('wav mp3 aac ogg oga flac'.split())
#TEXT = ('txt',)
#DATA = ...
#SCRIPTS = ...
#ARCHIVES = ...
#EXECUTABLES = ...
#DEFAULT = TEXT + DOCUMENTS + IMAGES + DATAapp.config['UPLOADED_MYPIC_ALLOW'] = IMAGES# 把剛剛app設置的config注冊到set_mypicconfigure_uploads(app, set_mypic)
# 此處WTF的SCRF密碼默認為和flask的SECRET_KEY一樣
# app.config['WTF_CSRF_SECRET_KEY'] = 'wtf csrf secret key'app.config['SECRET_KEY'] = 'xxxxx'
#允許上傳的文件大為10Mpatch_request_class(app,10*1024*1024)
class UploadForm(Form):    # 文件field設置為‘必須的’,過濾規則設置為‘set_mypic’
    upload = FileField('p_w_picpath', validators=[FileRequired('文件未選擇!'), FileAllowed(set_mypic, '只能上傳圖片!')])
    submit = SubmitField('上傳')

@app.route('/', methods=('GET', 'POST'))def index():
    form = UploadForm()
    url = None    if form.validate_on_submit():
        filename = secure_filename(form.upload.data.filename)
        fileupload = set_mypic.save(form.upload.data, name=filename)
url = set_mypic.url(fileupload)
    return render_template('index.html', form=form, url=url)if __name__ == '__main__':
    app.run(debug=True)
-----------------------------------------
安全上傳方法:
from flask_wtf import FlaskFormfrom flask_wtf.file import FileField, FileRequiredfrom werkzeug.utils import secure_filename
form = FlaskForm(csrf_enabled=False)
WTF_CSRF_ENABLED = False
WTF_CSRF_SECRET_KEY = 'a random string'
class PhotoForm(FlaskForm):    photo = FileField(validators=[FileRequired()])

@app.route('/upload', methods=['GET', 'POST'])def upload():    if form.validate_on_submit():        f = form.photo.data
        filename = secure_filename(f.filename)        f.save(os.path.join(app.instance_path, 'photos', filename))        return redirect(url_for('index'))    return render_template('upload.html', form=form)
------------------------------------------------
 html文件:
{% extends "base.html" %}
{% import "bootstrap/wtf.html" as wtf %}
    {% block page_content %}    {{ wtf.quick_form(form, enctype="multipart/form-data") }} 
    <h5>文件上傳成功!</h5>
    {% if url %}
    <br><img src="{{ url }}">    {% endif %}    {% endblock page_content %}
注:
上傳文件的 form 必須是 POST 方法,并且 enctype=multipart/form-data。type=file。
如果使用 GET 方法,則只會上傳文件名。
如何將照片資源與用戶進行綁定?
使用輕量級 ORM 框架,peewee,使用兩個字段 use_id、photo_name。將數據存儲到數據庫表格中。需要時可根據登錄 user 的 id 獲取到對應的 photo_name,然后使用 photos.url(photo_name) 進行加載。

創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。

網站建設哪家好,找創新互聯!專注于網頁設計、網站建設、微信開發、小程序開發、集團企業網站建設等服務項目。為回饋新老客戶創新互聯還提供了東方免費建站歡迎大家使用!

分享題目:flask-uploads擴展的使用-創新互聯
本文鏈接:http://vcdvsql.cn/article40/dioheo.html

成都網站建設公司_創新互聯,為您提供手機網站建設、網站策劃、企業網站制作、響應式網站企業建站Google

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都網站建設