捕获处理全局异常的方法有两种:@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用法:
文章参考链接:
flask捕获@app.errorhandler/@app.after_request全局异常总结_flask_孤独王者¥-华为云开发者联盟