升级到Flask 0.11要注意哪些问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了升级到Flask 0.11要注意哪些问题相关的知识,希望对你有一定的参考价值。
参考技术A 有哪些变化?Flask官方文档的变更日志中,提到了一共33处变化。我这里选择性地列出几个比较重大的变化,更详细的内容 请看文档 。
调试
新版本中移除了Flask应用中的 debug_log_format 属性,这意味着如果没有启用调试,那么Flask会默认记录日志,日志记录格式是硬编码在框架中的。不过开发者可以通过新增的 LOGGER_HANDLER_POLICY 配置键停用默认的日志记录程序,从而使用自定义的日志记录器。
模板
除了在调试模式之外,不会再自动重载模板。可以通过新增的 TEMPLATES_AUTO_RELOADT 配置键进行配置。
render_template_string()函数改为默认自动对模板变量进行自动转义,与 render_template() 的行为更加一致。
错误处理
在Flask中,一般推荐按如下方式注册错误处理程序:
@app.errorhandler(werkzeug.exceptions.BadRequest)
def handle_bad_request(e):
return 'bad request!'
在0.11版之前,如果在一个函数上装饰多个错误程序,那么各自的优先级是按照装饰/调用顺序处理。现在则改为按照异常的继承层级,意味着针对更加具体异常的处理程序会优先执行,而不再执行针对更普遍异常的程序。
另外,直接在应用实例上注册处理程序会报ValueError。
最重要的两个变化放到最后。
flask cli
最新的版本集成了Armin自己开发的 click 库,提供了 flask 命令行命令和 flask.cli模块,用于开启本地调试服务器。相对于过去使用 flask.run()方法,使用 flask 命令更快更可靠,而且可以替代 Flask-Script 第三方扩展。
在虚拟环境中安装Flask后,就可以直接在命令行使用 flask 命令。
模块导入
新版中弃用了以 flask.ext 形式导入扩展模块,应该改用 flask_foo。
如果你仍使用原来的形式,Flask 会对每个这样导入的扩展报 flask.exthook.ExtDeprecationWarning 警示。为了便利开发者,Flask团队提供了一个叫做 flask-ext-migrate 的迁移工具,可以自动改写导入语句。
Flask 打怪升级路线图,点击拾取
最终效果:
怎么样,有没有跃跃欲试一条龙通关的冲动,想学习 Flask 的同学,行动起来!另外 Flask 实现一个问答社区,目前正在折扣中,点击「阅读原文」,即可了解此课程详细信息。
以上是关于升级到Flask 0.11要注意哪些问题的主要内容,如果未能解决你的问题,请参考以下文章