@app.register_error_handler 是 Flask 中的一个装饰器,用于注册一个错误处理函数。与 @app.errorhandler 不同的是,它可以同时处理多种异常类型。
以下是一个示例
在这个示例中,我们定义了两个错误处理函数:handle_value_error 和 handle_type_error,分别用于处理 ValueError 和 TypeError 异常。
from flask import Flask, jsonify
app = Flask(__name__)
@app.route('/users/<int:user_id>')
def get_user(user_id):
# get user from database
user = None
if not user:
raise ValueError('User not found')
return jsonify(user)
def handle_value_error(error):
return jsonify({'message': str(error)}), 404
def handle_type_error(error):
return jsonify({'message': str(error)}), 400
app.register_error_handler(ValueError, handle_value_error)
app.register_error_handler(TypeError, handle_type_error)
if __name__ == '__main__':
app.run()
与 @app.errorhandler 不同的是,我们使用 app.register_error_handler 方法分别注册了这两个处理函数。
这样,当应用程序抛出 ValueError 或 TypeError 异常时,相应的处理函数就会被调用。这样可以更加灵活地处理不同类型的异常。
注意事项
需要注意的是,与 @app.errorhandler 不同的是,@app.register_error_handler 可以注册多个处理函数来处理不同类型的异常。
- 如果同一个异常类型在多个处理函数中都有对应的处理方式,最后一个处理函数会生效。
- 如果一个异常类型没有对应的处理函数,Flask 会使用默认的错误处理方式。默认情况下,Flask 会返回一个简单的错误页面,其中包含了错误信息。
- 如果希望自定义错误页面,可以在错误处理函数中返回一个渲染过的模板。
- 如果需要阻止异常继续向上传递,可以在错误处理函数中返回一个响应对象。
- 如果多个错误处理函数都返回了响应对象,最后一个返回的响应对象会被 Flask 返回到客户端。


