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

相关推荐
HsuHeinrich2 分钟前
利用径向柱图探索西班牙语学习数据
python·数据可视化
独行soc9 分钟前
2025年渗透测试面试题总结-105(题目+回答)
网络·python·安全·web安全·adb·渗透测试·安全狮
IT_陈寒21 分钟前
JavaScript性能飞跃:5个V8引擎优化技巧让你的代码提速300%
前端·人工智能·后端
史锦彪27 分钟前
用 PyTorch 实现 MNIST 手写数字识别:从入门到实践
人工智能·pytorch·python
董建光d29 分钟前
PyTorch 实现 MNIST 手写数字识别完整流程(含数据处理、模型构建与训练可视化)
人工智能·pytorch·python
Victor35634 分钟前
Redis(61)Redis的连接数上限是多少?
后端
Victor35638 分钟前
Redis(60) Redis的复制延迟如何优化?
后端
小宁爱Python2 小时前
从零搭建 RAG 智能问答系统3:聊天信息持久化和登录注册
python
天才少女爱迪生3 小时前
LLVM(Low Level Virtual Machine)介绍
python·数据挖掘
碳酸的唐6 小时前
A* 工程实践全指南:从启发式设计到可视化与性能优化
python·神经网络