Flask 学习笔记
一、设置为 Debug 模式
默认情况下 flask 不会开启 Debug 模式,开启 Debug 模式后,flask 会在每次保存代码的时候自动的重新载入代码,并且如果代码有错误,会在终端进行提示。开启 Debug 模式有三种方式:
- 直接在应用对象上设置
app.debug = True
app.run()
- 在执行 run 方法的时候,传递参数进去
app.run(debug=True)
- 在 config 属性中设置
app.config.update(DEBUG=True)
如果一切正常,会在终端打印以下信息:
* Debug mode: on (这里是 on 就表示开启了自动保存更新)
* Restarting with stat
* Debugger is active!
* Debugger pin code: 243-122-750
* Running on http://127.0.0.1:9000/ (Press CTRL+C to quit)
需要注意的是,只能在开发环境下开启 Debug 模式,因为 Debug 模式会带来非常大的安全隐患(比如回把错误信息暴露再页面)。
另外,在开启了 Debug 模式后,当程序有异常而进入错误堆栈模式,你第一次点击某个堆栈想查看变量值的时候,页面会弹出一个对话框,让你输入 PIN 值,这个 PIN 值在你启动的时候就会出现,比如在刚刚启动的项目中的 PIN 值为243-122-750
,你输入这个值后,Werkzeug 会把这个 PIN 值作为 cookie 的一部分保存起来,并在 8小时 后过期,8小时以内不需要再输入PIN值。这样做的目的是为了更加的安全,让调试模式下的攻击者更难攻击到本站。
二、配置文件
Flask 项目的配置,都是通过 app.config
对象来进行配置的。比如要配置一个项目处于 Debug 模式下,那么可以使用 app.config['DEBUG'] = True
来进行设置,那么 Flask 项目将以 Debug 模式运行。在 Flask 项目中,有四种方式进行项目的配置:
- 直接硬编码
app = Flask(__name__)
app.config['DEBUG'] = True
- 因为
app.config
是flask.config.Config
的实例,而 Config 类 是继承自 dict,因此可以通过update
方法
app.config.update(
DEBUG=True,
SECRET_KEY='...'
)
- .如果你的配置项特别多,你可以把所有的配置项都放在一个模块中,然后通过加载模块的方式进行配置,假设有一个 settings.py 模块,专门用来存储配置项的,此时你可以通过
app.config.from_object()
方法进行加载,并且该方法既可以接收模块的的字符串名称,也可以模块对象
# settings.py 文件
DEBUG = True
# 1. 通过模块字符串
app.config.from_object('settings')
app.run()
# 2. 通过模块对象
import settings
app.config.from_object(settings)
app.run()
- 也可以通过另外一个方法加载,该方法就是
app.config.from_pyfile()
,该方法传入一个文件名,通常是以.py
结尾的文件,但也不限于只使用.py
后缀的文件
# 文件要写后缀, 文件不限于 py 文件
# 不想找不到文件时报错可以加上参数 silent
app.config.from_pyfile('settings.py', silent=True)
app.run()