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

相关推荐
路小雨~几秒前
如何快速用测试用例来入门一个项目
python
打酱油的D4 分钟前
01. Node.js 运行时
前端·后端
Moe4886 分钟前
Redis 缓存三大经典问题:穿透、击穿与雪崩
java·后端·面试
不良人天码星9 分钟前
GUI自动化基础(一)
python·ui·自动化
我爱娃哈哈9 分钟前
SpringBoot + JSON 字段 + MySQL 8.0 函数索引:灵活存储半结构化数据,查询不慢
后端
卷Java19 分钟前
Python字典:键值对、get()方法、defaultdict,附通讯录实战
开发语言·数据库·python
七夜zippoe31 分钟前
区块链开发:从智能合约到DApp
python·区块链·智能合约·开发·dapp
hhhjllhj34 分钟前
如何用关键词优化报表提升网站流量?
python·搜索引擎·facebook
明月(Alioo)43 分钟前
Python 并发编程详解 - Java 开发者视角
java·开发语言·python
跟着珅聪学java1 小时前
编写高质量 CSS 样式完全指南
人工智能·python·tensorflow