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

相关推荐
Piar1231sdafa2 分钟前
YOLO11-Seg与Fasternet-BiFPN结合的枣果实品质检测系统实现详解
python
minglie14 分钟前
micropython 按键
python
阿豪只会阿巴4 分钟前
项目心得——发布者和订阅者问题解决思路
linux·开发语言·笔记·python·ubuntu·ros2
chilavert31823 分钟前
技术演进中的开发沉思-317 JVM:指令集(下)
开发语言·python
tjjucheng39 分钟前
小程序定制开发公司排名
python
27669582921 小时前
dy bd-ticket-guard-client-data bd-ticket-guard-ree-public-key 逆向
前端·javascript·python·abogus·bd-ticket·mstoken·ticket-guard
Maddie_Mo1 小时前
智能体设计模式 第一章:提示链
人工智能·python·语言模型·rag
m0_726365831 小时前
哈希分分预测系统 + Python Worker + Web 仪表盘”小系统(PHP + MySQL)
前端·python·哈希算法
武帝为此1 小时前
【RC4加密算法介绍】
网络·python·算法
李慕婉学姐2 小时前
Springboot旅游景点管理系统2fj40iq6(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端