Skip to main content

如何在Flask扩展开发的过程中加入异常日志

如何在Flask扩展开发的过程中加入异常日志

如何在Flask扩展开发的过程中加入异常日志

之前开发了一个扩展叫做flask_dxcaptcha

最近在使用他的过程中发现了一个问题,发现异常的时候直接导致使用的他的程序奔溃了,异常让人崩溃,但是不能给使用者带来崩溃,于是做了修复,加了下日志处理逻辑。

但是如果自己再定义一个好像显得有些麻烦,毕竟定义一套虽说可以更加责任化(就是出了问题知道是自己扩展的问题),但是既然是Flask扩展,应该跟使用Flask框架结合下会更好,于是决定先暂时这样处理吧,添加的代码如下

from flask import current_app

try:
    ......
except Exception as e:
    current_app.logger.exception(str(e))
    ......

测试如下

from flask import current_app

try:
	raise Exception('测试异常')
    ......
except Exception as e:
    current_app.logger.exception(str(e))
    ......

于是得到的异常结果如下

[2019-12-27 10:51:12,653] ERROR in captchaclient: 测试异常
Traceback (most recent call last):
  File "/Users/durban/python/baby/.env3_baby/lib/python3.7/site-packages/flask_dxcaptcha/captchaclient.py", line 57, in checkToken
    raise Exception('测试异常')
Exception: 测试异常
版权声明

版权声明

张大鹏 创作并维护的 Walkerfree 博客采用 创作共用保留署名-非商业-禁止演绎4.0国际许可证。本文首发于 Walkerfree 博客(http://www.walkerfree.com/),版权所有,侵权必究。本文永久链接:http://www.walkerfree.com/article/190