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_孤独王者¥-华为云开发者联盟

相关推荐
hrhcode几秒前
【Netty】三.ChannelPipeline与ChannelHandler责任链深度解析
java·后端·spring·springboot·netty
张3蜂8 分钟前
Python venv 详解:为什么要用、怎么用、怎么用好
开发语言·python
树獭叔叔12 分钟前
高级微调调优:NEFTune 鲁棒性增强与 RoPE 长度外推
后端·aigc·openai
老赵全栈实战16 分钟前
《从零搭建RAG系统第3天:文档加载+文本向量化+向量存入Milvus》
python
树獭叔叔19 分钟前
深度拆解:Weight Decay 与参数正则化的博弈论
后端·aigc·openai
火龙果研究院20 分钟前
在CentOS上安装Python 3.13需要从源码编译
开发语言·python·centos
龙山云仓37 分钟前
No156:AI中国故事-对话司马迁——史家绝唱与AI记忆:时间叙事与因果之链
大数据·开发语言·人工智能·python·机器学习
niuniudengdeng42 分钟前
一种基于高维物理张量与XRF实景复刻的一步闭式解工业级3D打印品生成模型
人工智能·python·数学·算法·3d
江湖十年42 分钟前
用 Go 语言还原 2026 春晚《惊喜定格》魔术!
后端·面试·go
overmind1 小时前
oeasy Python 114 在列表指定位置插入insert
开发语言·python