Flask 應(yīng)用程序的工廠函數(shù)

2021-08-11 09:45 更新

如果您已經(jīng)開始使用包和藍(lán)圖(用藍(lán)圖實現(xiàn)模塊化的應(yīng)用)輔助您的應(yīng)用開發(fā)了,那么 這里還有一些非常好的辦法可以進(jìn)一步的提升開發(fā)體驗。當(dāng)藍(lán)圖被導(dǎo)入的時候, 一個通用的模板將會負(fù)責(zé)創(chuàng)建應(yīng)用程序?qū)ο蟆5侨绻銓⑦@個對象的創(chuàng)建工作 移交給一個函數(shù)來完成,那么你就可以在此后創(chuàng)建它的多個實例。

這么做的目的在于:

  1. 測試。你可以使用多個應(yīng)用程序的實例,為每個實例分配分配不同的配置, 從而測試每一種不同的情況。
  2. 多個實例。想象以下情景:您需要同時運行同一個應(yīng)用的不同版本,您當(dāng)然可以 在你的Web服務(wù)器中配置多個實例并分配不同的配置,但是如果你使用工廠函數(shù), 你就可以在一個隨手即得的進(jìn)程中運行這一個應(yīng)用的不同實例了!

那么該如何使用他們呢?

基礎(chǔ)的工廠函數(shù)

您可以像下面展示的這樣,從一個函數(shù)里啟動這個應(yīng)用:

def create_app(config_filename):
    app = Flask(__name__)
    app.config.from_pyfile(config_filename)

    from yourapplication.views.admin import admin
    from yourapplication.views.frontend import frontend
    app.register_blueprint(admin)
    app.register_blueprint(frontend)

    return app

有得必有失,在導(dǎo)入時,您無法在藍(lán)圖中使用這個應(yīng)用程序?qū)ο?。然而您可以在一個 請求中使用他。如果獲取當(dāng)前配置下的對應(yīng)的應(yīng)用程序?qū)ο竽??請使? current_app 函數(shù):

from flask import current_app, Blueprint, render_template
admin = Blueprint('admin', __name__, url_prefix='/admin')

@admin.route('/')
def index():
    return render_template(current_app.config['INDEX_TEMPLATE'])

在這里我們從配置中查找一個網(wǎng)頁模板文件的名字。

使用應(yīng)用程序

所以,要使用這樣的一個應(yīng)用,你必須先創(chuàng)建這個應(yīng)用對象,這里是一個 運行此類程序的 run.py 文件的例子:

from yourapplication import create_app
app = create_app('/path/to/config.cfg')
app.run()

工廠函數(shù)的改進(jìn)

前文所提供的工廠函數(shù)并不是特別聰明好用,您可以改進(jìn)它,如下的 改變可以是直接且可行的:

  1. 使得在單元測試中傳入配置值成為可行,以使您不必在文件系統(tǒng)中 創(chuàng)建多個配置文件。
  2. 在程序初始時從藍(lán)圖中調(diào)用一個函數(shù),這樣您就有機會修改應(yīng)用的參數(shù)屬性了 (就像在在請求處理器前后的調(diào)用鉤子等)
  3. 如果必要的話,在應(yīng)用正在被創(chuàng)建時添加 WSGI 中間件。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號