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/