flask 加载配置文件

app.config(dict)属性来保存配置信息

1.从对象中加载
优点:可以发挥继承的优势,复用多个配置文件
缺点:需放在工程中

class DefaultConfig(object):
    """默认配置"""
    SECRET_KEY = '123123'

app = Flask(__name__)

app.config.from_object(DefaultConfig) # 载入对象

@app.route("/")
def index():
    print(app.config['SECRET_KEY'])
    return "hello world"

2.从配置文件中加载
优点:解耦不需要放在工程中
缺点:不可发挥继承的优势

setting.py

SECRET_KEY = '123'
app = Flask(__name__)

app.config.from_pyfile('setting.py')

@app.route("/")
def index():
    print(app.config['SECRET_KEY'])
    return "hello world"

3.从环境变量中加载
优点:
缺点:

终端输入:

export PROJECT_SETTING='~/setting.py'
app = Flask(__name__)

app.config.from_envvar('PROJECT_SETTING', silent=True) # silent为True不报错

@app.route("/")
def index():
    print(app.config['SECRET_KEY'])
    return "hello world"

4.总结
在实际生产环境中:
1.使用配置对象加载默认配置
2.使用环境变量加载不想出现在代码中的敏感信息

def create_flask_app(config):
    app = Flask(__name__)
    app.config.from_object(config) # 先加载配置文件
    app.config.from_envvar("PROJECT_SETTING", silent=True) # 再加载,会覆盖掉上面的配置
    return app

class DefaultConfig(object):
    SECRET_KEY = 'itcast1'
class DevelopmentConfig(DefaultConfig):
    DEBUG=True

app = create_flask_app(DevelopmentConfig)

@app.route("/")
def index():
    print(app.config['SECRET_KEY'])
    return "hello world"

参考:
https://flask.palletsprojects.com/en/1.0.x/config/


版权声明:本文为claroja原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。