在view函數中,如果需要中斷request,可以使用abort(500)或者直接raise exception。當然我們還需要返回一個出錯信息給前端,所以需要定制一下ErrorHandler。一般只需要兩個個handler即可,一個是404錯誤,一個是500一類的服務器端錯誤。當然也可以自定義錯誤。
abort中斷請求
# 在flask中可以通過abort中斷觸發請求對應的狀態碼 from flask import abort @app.route('/') def index(): abort(401) # 請求到此即中斷,不會打印下面的語句,並返回HTTP狀態碼401 print '123'
errorhandler捕捉當前app或藍圖的狀態碼,並進行自定制處理
下面是一份示例代碼,admin是一個藍本或者app,發生404錯誤或500錯誤,會返回一個Json對象給請求段。
from flask import jsonify
from . import admin
@admin.errorhandler(404)
def error_404(error):
"""這個handler可以catch住所有abort(404)以及找不到對應router的處理請求"""
response = dict(status=0, message="404 Not Found")
return jsonify(response), 404
@admin.errorhandler(Exception)
def error_500(error):
"""這個handler可以catch住所有的abort(500)和raise exeception."""
response = dict(status=0, message="500 Error")
return jsonify(response), 400
class MyError(Exception):
"""自定義錯誤類"""
pass
@admin.errorhandler(MyError)
def MyErrorHandle(error):
response = dict(status=0, message="400 Error")
return jsonify(response), 400
app_errorhandler捕捉全局狀態碼,並進行自定制異常處理
在藍本中編寫錯誤處理程序有點不同,如果使用errorhandler修飾器,那么只有藍本中的錯誤才會觸發。如果想注冊全局的錯誤處理程序,要用app_errorhandler。
例如:
from . import auth
@auth.app_errorhandler(404)
def error_404(error):
response = dict(status=0, message="404 Not Found")
return jsonify(response), 404
補充說明
當我們不是使用的工廠模式創建app時,app.errorhandler(401),即可捕捉全局401狀態;若使用了create_app方式創建app,則無法進行捕捉,若想捕捉,可以在藍圖中寫,如admin.errorhandler(401),即捕捉admin藍圖下所有401狀態碼,admin.app_errorhandler(401),則是捕捉的全局的401狀態碼,即其他藍圖中的401狀態,也會被捕捉,進行處理
