Flask小總結+實例化Flask參數以及對app的配置


    Flask 小而精 三方組件全 
    穩定性相對較差
    
    1.啓動:
        from flask import Flask
        app = Flask(__name__)
        app.run("0.0.0.0",5000,debug=True)
        
    2.加入路由
        @app.route("/",methods=("GET","POST"))
        def index():
            return "123"
            
    3.Response三劍客 + 小兒子:
        HTTPResponse return "httpresponse"
        from flask import redirect
        redirect: return redirect("/")
        from flask import render_template
        render: return render_template - templates
        小兒子:
        from flask import send_file , jsonify        
        return send_file() 打開並返回文件內容
        return jsonify() Content-Type: application/json
    
    4.request 
        from flask import request 公共變量 - 數據安全性?
        request.form 表單數據,FormData 字典 to_dict
        request.args URL中的參數,數據
        request.json Content-Type:application/json 請求頭
        request.data Content-Type不被承認 將原始數據存放在data b""
        request.values 存放 FormData URL 通常狀況下 to_dict
        request.files 獲取文件 save 保存
        request.method
        request.path
        
    5.Jinja:
        {{}} 引用和執行
        {%%} 邏輯代碼
    
    6.session: Flask-session
        將 session 加密後存放在瀏覽器的 Cookie
        from flask import session
        app.secret_key = "ward1"  
        session["user"] = "ward2"
        session.get("user")
        
    
    寫裝飾器 基於session 驗證用戶有效性


    1.Flask 中的路由 
        *endpoint - url_for 反向地址
        *endpoint 默認是視圖函數名
        *methods 指定視圖函數的請求方式,默認GET
        defaults={"nid":1} 指定視圖函數的默認參數
        strict_slashes=False 是否嚴格遵循路由規則 /login/
        redirect_to="/login" 永久跳轉地址 301
        
        *動態路由參數:
        /<int:nid>  /<string:str> /<nid> 
        視圖函數中須要有參數接收動態路由參數
        
    2.Flask中的實例化配置
        *template_folder = "temp"  # template模板目錄, 默認當前項目中的 templates 目錄
        *static_folder = "jingtaiwenjianmulu" 目錄
        *static_url_path = "/static" 訪問路徑
        static_host = "http://xx.xxx.com/static"  cdn靜態文件服務器配置
        
        host_matching = False,  # 若是不是特別須要的話,慎用,不然全部的route 都須要host=""的參數
        subdomain_matching = False,  # 理論上來講是用來限制SERVER_NAME子域名的,可是目前尚未感受出來區別在哪裏
        instance_path = None,  # 指向另外一個Flask實例的路徑
        instance_relative_config = False  # 是否加載另外一個實例的配置
        root_path = None  # 主模塊所在的目錄的絕對路徑,默認項目目錄
        
    3.app對象配置
        app.config.from_object(Debug)
        class Debug(object):
            DEBUG=True
    
    4.藍圖 Blueprint
        form flask import Blueprint
        blue = Blueprint("blue_id",__name__,url_prefix)
        url_prefix 前綴
        app.register_blueprint(blue)
    
    5.特殊裝飾器:
        @app.template_global()
        @app.template_filter()
        
        @app.before_request
            請求進入視圖函數以前
            
        @app.after_request
        def af1(response)
            return response
            結束視圖函數以後,返回客戶端以前
            
        
        正常:be1 - be2 - be3 - af3 - af2 - af1 
        異常:be1 - af3 - af2 - af1
        
        @app.errorhandler(404) 重定義頁面
        def error404(args):
        
    基於藍圖實現增刪改查數據 基於Before_request session 實現用戶校驗
    可選errorhandler
               

 

1.CBV :
    from flask import views
    
    class LoginView(views.MethodView):
        def get(self):
            return
            
        def post(self):
            return
            
    
    app.add_url_rule("/login",endpoint=None,view_func=LoginView.as_view("login"))
    
2.flash:
    from flask import flash,get_flash_messages
    
    flash("","tag")
    get_flash_messages("tag")
    

3.Flask-Session
    from flask_session import Session
    from flask import session
    
    app.config["SESSION_TYPE"] = "redis"
    app.config["SESSION_REDIS"] = Redis("127.0.0.1",6379,db=7)
    Session(app)
    
    session["user"] == "123"
    session.get("user")
    


4.WTForms - MoudelForm
    from wtfroms.fields import simple,core
    from wtfroms import Form,validators
    
    class LoginForm(Form):
        username = simple.StringFields(
            label = "" #看源碼 __init__
        )
        
    
    lf = LoginForm()
    render_template("html",lf=lf)
    
    {{ lf.uername }}
    {{ lf.uername.label }}
    {{ lf.uername.errors.0 }}
    
    lf = LoginForm(request.form)
    
    if not lf.validata():
        render_template("html",lf=lf)
    
    lf.data.get("username")
    

 

實例化Flask參數以及對app的配置

 

Flask 是一個很是靈活且短小精幹的web框架 , 那麼靈活性從什麼地方體現呢?html

有一個神奇的東西叫 Flask配置 , 這個東西怎麼用呢? 它能給咱們帶來怎麼樣的方便呢?web

首先展現一下:redis

from flask import Flask

app = Flask(__name__)  # type:Flask
app.config["DEBUG"] = True

這句 app.config["DEBUG"] = True 能夠實現的功能可刺激了json

代碼只要發生改動,自動重啓Flask程序(app.run)flask

在控制檯打印的信息很是全面瀏覽器

以上兩個功能就是傳說中的 DEBUG 模式(調試模式)緩存

Flask的配置就是在 app.config 中添加一個鍵值對,可是你存進去的鍵必須是config中應該存在的,若是再也不存在的話,它會默認無用,就這麼放着安全

config中有多少有用的key 呢?服務器

{
    'DEBUG': False,  # 是否開啓Debug模式
    'TESTING': False,  # 是否開啓測試模式
    'PROPAGATE_EXCEPTIONS': None,  # 異常傳播(是否在控制檯打印LOG) 當Debug或者testing開啓後,自動爲True
    'PRESERVE_CONTEXT_ON_EXCEPTION': None,  # 一兩句話說不清楚,通常不用它
    'SECRET_KEY': None,  # 以前遇到過,在啓用Session的時候,必定要有它
    'PERMANENT_SESSION_LIFETIME': 31,  # days , Session的生命週期(天)默認31天
    'USE_X_SENDFILE': False,  # 是否棄用 x_sendfile
    'LOGGER_NAME': None,  # 日誌記錄器的名稱
    'LOGGER_HANDLER_POLICY': 'always',
    'SERVER_NAME': None,  # 服務訪問域名
    'APPLICATION_ROOT': None,  # 項目的完整路徑
    'SESSION_COOKIE_NAME': 'session',  # 在cookies中存放session加密字符串的名字
    'SESSION_COOKIE_DOMAIN': None,  # 在哪一個域名下會產生session記錄在cookies中
    'SESSION_COOKIE_PATH': None,  # cookies的路徑
    'SESSION_COOKIE_HTTPONLY': True,  # 控制 cookie 是否應被設置 httponly 的標誌,
    'SESSION_COOKIE_SECURE': False,  # 控制 cookie 是否應被設置安全標誌
    'SESSION_REFRESH_EACH_REQUEST': True,  # 這個標誌控制永久會話如何刷新
    'MAX_CONTENT_LENGTH': None,  # 若是設置爲字節數, Flask 會拒絕內容長度大於此值的請求進入,並返回一個 413 狀態碼
    'SEND_FILE_MAX_AGE_DEFAULT': 12,  # hours 默認緩存控制的最大期限
    'TRAP_BAD_REQUEST_ERRORS': False,
    # 若是這個值被設置爲 True ,Flask不會執行 HTTP 異常的錯誤處理,而是像對待其它異常同樣,
    # 經過異常棧讓它冒泡地拋出。這對於須要找出 HTTP 異常源頭的可怕調試情形是有用的。
    'TRAP_HTTP_EXCEPTIONS': False,
    # Werkzeug 處理請求中的特定數據的內部數據結構會拋出一樣也是「錯誤的請求」異常的特殊的 key errors 。
    # 一樣地,爲了保持一致,許多操做能夠顯式地拋出 BadRequest 異常。
    # 由於在調試中,你但願準確地找出異常的緣由,這個設置用於在這些情形下調試。
    # 若是這個值被設置爲 True ,你只會獲得常規的回溯。
    'EXPLAIN_TEMPLATE_LOADING': False,
    'PREFERRED_URL_SCHEME': 'http',  # 生成URL的時候若是沒有可用的 URL 模式話將使用這個值
    'JSON_AS_ASCII': True,
    # 默認狀況下 Flask 使用 ascii 編碼來序列化對象。若是這個值被設置爲 False ,
    # Flask不會將其編碼爲 ASCII,而且按原樣輸出,返回它的 unicode 字符串。
    # 好比 jsonfiy 會自動地採用 utf-8 來編碼它而後才進行傳輸。
    'JSON_SORT_KEYS': True,
    #默認狀況下 Flask 按照 JSON 對象的鍵的順序來序來序列化它。
    # 這樣作是爲了確保鍵的順序不會受到字典的哈希種子的影響,從而返回的值每次都是一致的,不會形成無用的額外 HTTP 緩存。
    # 你能夠經過修改這個配置的值來覆蓋默認的操做。但這是不被推薦的作法由於這個默認的行爲可能會給你在性能的代價上帶來改善。
    'JSONIFY_PRETTYPRINT_REGULAR': True,
    'JSONIFY_MIMETYPE': 'application/json',
    'TEMPLATES_AUTO_RELOAD': None,
}

以上這些Key,均可以被改寫,固然他們也都是有默認值存在的,若是沒有特殊狀況,不要改寫它的默認值cookie

修改配置的方式大約是兩種

1.直接對app.config進行修改

app.config["DEBUG"] = True

2.使用類的方式導入

首先要有一個settings.py的文件

class FlaskSetting:
    DEBUG = True
    SECRET_KEY = "DragonFire"

而後咱們在Flask的啓動文件中就能夠這麼寫

from flask import Flask


app = Flask(__name__)  # type:Flask
app.config.from_object("settings.FlaskSetting")

這叫作類導入配置

 

這是針對一個已經實例化的app進行的配置

那麼在Flask實例化的時候,傳遞的參數是什麼鬼呢?

其實能夠理解爲對Flask實例進行的初始配置,這裏面的參數是很是好理解,注意關鍵字是很是很是很是好理解

static_folder = 'static',  # 靜態文件目錄的路徑 默認當前項目中的static目錄
static_host = None,  # 遠程靜態文件所用的Host地址,默認爲空
static_url_path = None,  # 靜態文件目錄的url路徑 默認不寫是與static_folder同名,遠程靜態文件時複用
# host_matching是否開啓host主機位匹配,是要與static_host一塊兒使用,若是配置了static_host, 則必須賦值爲True
# 這裏要說明一下,@app.route("/",host="localhost:5000") 就必需要這樣寫
# host="localhost:5000" 若是主機頭不是 localhost:5000 則沒法經過當前的路由
host_matching = False,  # 若是不是特別須要的話,慎用,不然全部的route 都須要host=""的參數
subdomain_matching = False,  # 理論上來講是用來限制SERVER_NAME子域名的,可是目前尚未感受出來區別在哪裏
template_folder = 'templates'  # template模板目錄, 默認當前項目中的 templates 目錄
instance_path = None,  # 指向另外一個Flask實例的路徑
instance_relative_config = False  # 是否加載另外一個實例的配置
root_path = None  # 主模塊所在的目錄的絕對路徑,默認項目目錄

這裏面,咱們經常使用的參數有

static_folder = 'static',  # 靜態文件目錄的路徑 默認當前項目中的static目錄
static_url_path = None,  # 靜態文件目錄的url路徑 默認不寫是與static_folder同名,遠程靜態文件時複用
template_folder = 'templates'  # template模板目錄, 默認當前項目中的 templates 目錄

記住這些就行了,通常的項目中,只修改這些參數

相關文章
相關標籤/搜索