flask捕获@app.errorhandler/@app.after_request全局异常总结

复制代码
捕获处理全局异常的方法有两种:@app.errorhandler、@app.after_request
1、第一种的使用,需要将flask的debug开关打开才能生效(自动捕获异常),在config里面将DEBUG = TRUE就可以(默认是False)。
但是,debug模式是万万不建议在生产中开启的,因此,这里这个用法就有所限制了。
复制代码
@app.errorhandler(Exception)
def handle_error(e):
    logging.error('error: {0} traceback:{1}'.format(e, traceback.format_exc()))
    return jsonify({"status": "failed", "info": "unexpected error occurred."})
复制代码
2、由于上面第一种方法的巨大局限性(生产不建议开启debug模式),开始考虑第二种方案,因此,考虑到用after_request装饰器来统一处理,通过获取请求的response的状态码来做判断,进行统一处理。需要注意的是,用after_request这种方法需要将debug模式关闭,要不flask自动捕获了异常,装饰器就捕获不到了。
复制代码
@app.after_request
def after_request(response):
    if response.status_code != 200:
        return make_response(jsonify({"msg": "unexpected error occurred."}), 200)
    return response

3、总结:@app.errorhandler和@app.after_request是不能一起使用的,一个对应开发模式,一个适合生产模式。

debug用法:

python flask框架 debug功能-CSDN博客

文章参考链接:

flask捕获@app.errorhandler/@app.after_request全局异常总结_flask_孤独王者¥-华为云开发者联盟

相关推荐
旷世奇才李先生5 分钟前
PyCharm 安装使用教程
ide·python·pycharm
程序员爱钓鱼19 分钟前
Go语言泛型-泛型约束与实践
前端·后端·go
寻月隐君19 分钟前
保姆级教程:Zsh + Oh My Zsh 终极配置,让你的 Ubuntu 终端效率倍增
linux·后端·命令行
程序员爱钓鱼21 分钟前
Go语言泛型-泛型对代码结构的优化
后端·google·go
这里有鱼汤26 分钟前
“对象”?对象你个头!——Python世界观彻底崩塌的一天
后端·python
RainbowSea29 分钟前
跨域问题(Allow CORS)解决(3 种方法)
java·spring boot·后端
尘浮72836 分钟前
60天python训练计划----day59
开发语言·python
wh393339 分钟前
使用Python将PDF转换成word、PPT
python·pdf·word
船长@Quant1 小时前
数学视频动画引擎Python库 -- Manim Voiceover 语音服务 Speech Services
python·数学·manim·动画引擎·语音旁白
sniper_fandc2 小时前
SpringBoot系列—入门
java·spring boot·后端