项目配置

设置为DEBUG模式:

默认情况下flask不会开启DEBUG模式,开启DEBUG模式后,flask会在每次保存代码的时候自动的重新载入代码,并且如果代码有错误,会在终端进行提示。
开启DEBUG模式有三种方式:

  1. 直接在应用对象上设置:

    1. app.debug = True
    2. app.run()
  2. 在执行run方法的时候,传递参数进去:

    1. app.run(debug=True)
  3. config属性中设置:

    1. app.config.update(DEBUG=True)
  4. 如果一切正常,会在终端打印以下信息: ```python

  • Restarting with stat
  • Debugger is active!
  • Debugger pin code: 294-745-044
  • Running on http://0.0.0.0:9000/ (Press CTRL+C to quit) `` 需要注意的是,只能在开发环境下开启DEBUG模式,因为DEBUG模式会带来非常大的安全隐患。<br />另外,在开启了DEBUG模式后,当程序有异常而进入错误堆栈模式,你第一次点击某个堆栈想查看变量值的时候,页面会弹出一个对话框,让你输入PIN值,这个PIN值在你启动的时候就会出现,比如在刚刚启动的项目中的PIN值为294-745-044,你输入这个值后,Werkzeug会把这个PIN值作为cookie`的一部分保存起来,并在8小时候过期,8小时以内不需要再输入PIN值。这样做的目的是为了更加的安全,让调试模式下的攻击者更难攻击到本站。

    配置文件:

    Flask项目的配置,都是通过app.config对象来进行配置的。比如要配置一个项目处于DEBUG模式下,那么可以使用app.config['DEBUG] = True来进行设置,那么Flask项目将以DEBUG模式运行。在Flask项目中,有四种方式进行项目的配置:
  1. 直接硬编码:

    1. app = Flask(__name__)
    2. app.config['DEBUG'] = True
  2. 因为app.configflask.config.Config的实例,而Config类是继承自dict,因此可以通过update方法:

    1. app.config.update(
    2. DEBUG=True,
    3. SECRET_KEY='...'
    4. )
  3. 如果你的配置项特别多,你可以把所有的配置项都放在一个模块中,然后通过加载模块的方式进行配置,假设有一个settings.py模块,专门用来存储配置项的,此时你可以通过app.config.from_object()方法进行加载,并且该方法既可以接收模块的的字符串名称,也可以模块对象:

    1. # 1. 通过模块字符串
    2. app.config.from_object('settings')
    3. # 2. 通过模块对象
    4. import settings
    5. app.config.from_object(settings)
  4. 也可以通过另外一个方法加载,该方法就是app.config.from_pyfile(),该方法传入一个文件名,通常是以.py结尾的文件,但也不限于只使用.py后缀的文件:

    1. app.config.from_pyfile('settings.py',silent=True)
    2. # silent=True表示如果配置文件不存在的时候不抛出异常,默认是为False,会抛出异常。

    Flask项目内置了许多的配置项,所有的内置配置项,可以在这里查看