亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flask學(xué)習(xí)之全局異常處理詳解

 更新時(shí)間:2023年06月25日 14:16:24   作者:逃逸的卡路里  
Flask是一個(gè)基于Python的Web框架,它提供了全局異常處理的機(jī)制來(lái)捕獲和處理應(yīng)用程序中的異常,下面就帶大家深入了解一下Flask是如何實(shí)現(xiàn)異常處理的,希望對(duì)大家有所幫助

前言

關(guān)于客戶端/服務(wù)端異常,先看段樣例代碼:

from flask import *
from paddlenlp import Taskflow
from werkzeug.exceptions import HTTPException
app = Flask(__name__)
app.config['JSON_AS_ASCII'] = False
@app.errorhandler(Exception)
def handle_500_exception(e):
    # pass through HTTP errors
    if isinstance(e, HTTPException):
        return e
    # now you're handling non-HTTP exceptions only
    return render_template("500_generic.html", e=e), 500
@app.errorhandler(HTTPException)
def handle_exception(e):
    response = e.get_response()
    response.data = json.dumps({
        "code": e.code,
        "name": e.name,
        "description": e.description,
    })
    response.content_type = "application/json"
    return response
class RequestParamException(HTTPException):
    code = 400
def handle_param_exception(e):
    response = e.get_response()
    response.data = json.dumps({
        "code": e.code,
        "name": "子類:RequestParamException 處理的異常。",
        "description": e.description,
    })
    response.content_type = "application/json"
    return response
@app.route('/add_user', methods=['POST'])
def add_documents():
    data = request.get_json()
    user = data['user']
    if user is None or len(user) <= 0:
        raise RequestParamException(description="user 不能為 None 或 ''。")
    return {"user": user}, 201
if __name__ == '__main__':
    app.register_error_handler(RequestParamException, handle_param_exception)
    app.run(debug=True)

一、Flask是什么

Flask是一個(gè)基于Python的Web框架,它提供了全局異常處理的機(jī)制來(lái)捕獲和處理應(yīng)用程序中的異常。下面將詳細(xì)介紹ask的全局異常處理、裝飾器模式、工廠模式、assert觸發(fā)異常、raise觸發(fā)異常、abort觸發(fā)異常以及異常處理的正常請(qǐng)求、異常請(qǐng)求、客戶端異常和服務(wù)器異常,并提供相應(yīng)的代碼示例。

二、Flask異常處理的整體流程

1.異常注冊(cè)

在Flask應(yīng)用程序中,通過(guò)@app.errorhandler裝飾器將異常類型與處理函數(shù)綁定。這樣做的目的是在應(yīng)用程序運(yùn)行過(guò)程中捕獲特定類型的異常,并進(jìn)行適當(dāng)?shù)奶幚怼?梢詾椴煌腍TTP狀態(tài)碼或其他異常類型注冊(cè)相應(yīng)的處理函數(shù)。

from flask import Flask
app = Flask(__name__)
@app.errorhandler(404)
def handle_not_found_error(error):
    return "Page not found", 404
@app.errorhandler(Exception)
def handle_generic_error(error):
    return "Internal Server Error", 500
if __name__ == '__main__':
    app.run()

在上述代碼中,使用@app.errorhandler(404)裝飾器將handle_not_found_error函數(shù)與404錯(cuò)誤綁定,而handle_generic_error則是注冊(cè)的通用異常處理函數(shù)。

2.異常觸發(fā)

當(dāng)應(yīng)用程序中發(fā)生異常時(shí),F(xiàn)lask會(huì)根據(jù)異常類型自動(dòng)觸發(fā)相應(yīng)的異常。異常的觸發(fā)可以有多種方式,例如路由函數(shù)中拋出異常、使用abort函數(shù)手動(dòng)引發(fā)HTTP異常等。

from flask import Flask, abort
app = Flask(__name__)
@app.route('/')
def index():
    # 觸發(fā)異常方式一:拋出異常
    raise ValueError("Something went wrong")
@app.route('/users/<int:user_id>')
def get_user__':
    app.run()

assert觸發(fā)異常: 在Python中,使用assert語(yǔ)句可以檢查某個(gè)條件是否為真,如果條件為假,則會(huì)觸發(fā)AssertionError異常。在Flask中,可以利用assert語(yǔ)句進(jìn)行請(qǐng)求參數(shù)的校驗(yàn)。

raise觸發(fā)異常: 在Python中,使用raise語(yǔ)句可以顯式地觸發(fā)特定的異常。在Flask應(yīng)用程序中,我們可以根據(jù)需要觸發(fā)不同類型的異常來(lái)處理業(yè)務(wù)邏輯。

abort觸發(fā)異常: 在Flask中,可以使用abort函數(shù)手動(dòng)觸發(fā)HTTP錯(cuò)誤。abort函數(shù)默認(rèn)觸發(fā)一個(gè)HTTPException異常。

3.異常處理

當(dāng)異常被觸發(fā)后,F(xiàn)lask會(huì)尋找與該異常類型對(duì)應(yīng)的注冊(cè)處理函數(shù),并將控制權(quán)轉(zhuǎn)移到相應(yīng)的處理函數(shù)。在異常處理函數(shù)中,可以根據(jù)需要進(jìn)行自定義的異常信息返回、日志記錄或其他操作。

from flask import Flask, jsonify
app = Flask(__name__)
@app.errorhandler(404)
def handle_not_found_error(error):
    return jsonify({"message": "Page not found"}), 404
@app.errorhandler(Exception)
def handle_generic_error(error):
    app.logger.error("An error occurred: %s", error)
    return jsonify({"message": "Internal Server Error"}), 500
if __name__ == '__main__':
    app.run()

異常處理函數(shù)中,handle_not_found_error處理404錯(cuò)誤并返回自定義的JSON響應(yīng)。而handle_generic_error則是通用的異常處理函數(shù),在發(fā)生任何未捕獲的異常時(shí)都會(huì)調(diào)用,它記錄了錯(cuò)誤日志并返回適當(dāng)?shù)腻e(cuò)誤響應(yīng)。

三、客戶端異常和服務(wù)端異常

客戶端異常是由于客戶端錯(cuò)誤導(dǎo)致的異常,例如無(wú)效的請(qǐng)求、身份驗(yàn)證失敗等。服務(wù)器異常則是由于服務(wù)器錯(cuò)誤導(dǎo)致的異常,如應(yīng)用程序崩潰、數(shù)據(jù)庫(kù)連接問(wèn)題等。

1.客戶端異常

客戶端異常是由客戶端的無(wú)效請(qǐng)求或操作引起的。對(duì)于客戶端異常,應(yīng)注意以下事項(xiàng):

適當(dāng)?shù)腍TTP狀態(tài)碼:返回正確的HTTP狀態(tài)碼來(lái)表示客戶端錯(cuò)誤。常見(jiàn)的狀態(tài)碼包括400(錯(cuò)誤請(qǐng)求)、401(未授權(quán))、403(禁止訪問(wèn))等。

from flask import Flask, jsonify
app = Flask(__name__)
@app.route('/login', methods=['POST'])
def login():
    username = request.form.get('username')
    password = request.form.get('password')
    if not username or not password:
        # 返回400錯(cuò)誤狀態(tài)碼和錯(cuò)誤信息
        return jsonify({"error": "Invalid username or password"}), 400
    # 進(jìn)行身份驗(yàn)證邏輯...
if __name__ == '__main__':
    app.run()

在上述代碼中,如果缺少用戶名或密碼,服務(wù)器將返回400錯(cuò)誤狀態(tài)碼和錯(cuò)誤信息。

錯(cuò)誤處理裝飾器:可以使用裝飾器捕獲客戶端異常,并返回適當(dāng)?shù)捻憫?yīng)。例如,使用@app.errorhandler(400)裝飾器來(lái)捕獲400錯(cuò)誤。

from flask import Flask, jsonify
app = Flask(_name_)
@app.errorhandler(400)
def handle_bad_request_error(error):
    return jsonify({"error": "Bad Request"}), 400
@app.route('/login', methods=['POST'])
def login():
    username = request.form.get('username')
    password = request.form.get('password')
    if not username or not password:
        # 返回400錯(cuò)誤狀態(tài)碼,裝飾器的處理函數(shù)會(huì)被觸發(fā)
        abort(400)
    # 進(jìn)行身份驗(yàn)證邏輯...
if __name__ == '__main__':
    app.run()

如果缺少用戶名或密碼,在login函數(shù)中使用abort(400)觸發(fā)400錯(cuò)誤,然后由handle_bad_request_error處理該錯(cuò)誤并返回自定義的錯(cuò)誤響應(yīng)。

2.服務(wù)器異常

服務(wù)器異常是由于服務(wù)器端錯(cuò)誤導(dǎo)致的異常。對(duì)于服務(wù)器異常,需要注意以下事項(xiàng):

1.錯(cuò)誤日志記錄

在發(fā)生服務(wù)器異常時(shí),及時(shí)記錄錯(cuò)誤信息到日志文件中,以便進(jìn)行故障排查和問(wèn)題修復(fù)。

import logging
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
    try:
        # 一些潛在的引發(fā)異常的操作
        raise ValueError("Something went wrong")
    except Exception as e           app.logger.error("An error occurred: %s", str(e))
        # 返回通用的服務(wù)器錯(cuò)誤響應(yīng)
        return "Internal Server Error", 500
if __name__ == '__main       
	app.run()

當(dāng)發(fā)生異常app.logger.error將錯(cuò)誤信息記錄到應(yīng)用程序的日志中。

2.通用的錯(cuò)誤處理

捕獲和處理未處理的服務(wù)器異常,并返回適當(dāng)?shù)腻e(cuò)誤響應(yīng)給客戶端。

from flask import Flask, jsonify
app = Flask(__name__)
@app.errorhandler(Exception)
def handle_generic_error(error):
    app.logger.error("An error occurred: %s", error)
    # 返回自定義的服務(wù)器錯(cuò)誤響應(yīng)
    return jsonify({"error": "Internal Server Error"}), 500
@app.route('/')
def index():
    try:
        # 一些潛在的引發(fā)異常的操作
        raise ValueError("Something went wrong")
    except Exception as:
        # 觸發(fā)異常后由異常處理函數(shù)進(jìn)行處理
        return handle_generic_error(e)
if __name__ == '__main__':
    app.run()

當(dāng)發(fā)生異常時(shí),調(diào)用handle_generic_error進(jìn)行處理并返回自定義的服務(wù)器錯(cuò)誤響應(yīng)。例模式可將處理邏輯從路由函數(shù)中分離出來(lái)。

總結(jié)

1、注冊(cè)處理函數(shù),將特定類型的異常與相應(yīng)的處理函數(shù)綁定。

2、在應(yīng)用程序執(zhí)行過(guò)程中,如果發(fā)生異常,F(xiàn)lask會(huì)尋找匹配的異常處理函數(shù)。

3、匹配到異常處理函數(shù)后,控制權(quán)轉(zhuǎn)移到異常處理函數(shù),并執(zhí)行相4、應(yīng)的處理邏輯。

5、異常處理函數(shù)可以根據(jù)需要進(jìn)行自定義的異常信息返回、日志記錄或其他操作。

6、處理完異常后,F(xiàn)lask會(huì)返回相應(yīng)的錯(cuò)誤響應(yīng)給客戶端。

參考文獻(xiàn):Flask開(kāi)發(fā)技巧之異常處理

到此這篇關(guān)于Flask學(xué)習(xí)之全局異常處理詳解的文章就介紹到這了,更多相關(guān)Flask全局異常處理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Python的web.py框架實(shí)現(xiàn)類似Django的ORM查詢的教程

    使用Python的web.py框架實(shí)現(xiàn)類似Django的ORM查詢的教程

    這篇文章主要介紹了使用Python的web.py框架實(shí)現(xiàn)類似Django的ORM查詢的教程,集成的ORM操作數(shù)據(jù)庫(kù)向來(lái)是Python最強(qiáng)大的功能之一,本文則探討如何在web.py框架上實(shí)現(xiàn),需要的朋友可以參考下
    2015-05-05
  • django自定義模板標(biāo)簽過(guò)程解析

    django自定義模板標(biāo)簽過(guò)程解析

    這篇文章主要介紹了django自定義模板標(biāo)簽過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • 解決使用python print打印函數(shù)返回值多一個(gè)None的問(wèn)題

    解決使用python print打印函數(shù)返回值多一個(gè)None的問(wèn)題

    這篇文章主要介紹了解決使用python print打印函數(shù)返回值多一個(gè)None的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • django中靜態(tài)文件配置static的方法

    django中靜態(tài)文件配置static的方法

    我們可以使用Template 設(shè)置我們的網(wǎng)頁(yè),同時(shí),一個(gè)完美的網(wǎng)頁(yè)需要css,js,image 等靜態(tài)文件的支持,這篇文章主要介紹了django中靜態(tài)文件配置static的方法,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 一文讀懂Python的’=='和’is’用法

    一文讀懂Python的’=='和’is’用法

    探索Python世界的'=='與'is',一個(gè)看似簡(jiǎn)單卻隱藏玄機(jī)的話題,本指南將帶你輕松讀懂它們背后的故事,解鎖編程中的這道難題,開(kāi)始我們的快速之旅,釋放代碼的潛能吧!
    2024-01-01
  • python區(qū)塊及區(qū)塊鏈的開(kāi)發(fā)詳解

    python區(qū)塊及區(qū)塊鏈的開(kāi)發(fā)詳解

    這篇文章主要介紹了python區(qū)塊及區(qū)塊鏈的開(kāi)發(fā)詳解的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Python實(shí)現(xiàn)常見(jiàn)限流算法的示例代碼

    Python實(shí)現(xiàn)常見(jiàn)限流算法的示例代碼

    在系統(tǒng)的穩(wěn)定性設(shè)計(jì)中,需要考慮到的就是限流,避免高并發(fā)環(huán)境下一下子把服務(wù)整垮了,本文為大家整理了一些Python實(shí)現(xiàn)的常見(jiàn)限流算法,希望對(duì)大家有所幫助
    2024-03-03
  • 如何利用pyecharts畫(huà)好看的餅狀圖

    如何利用pyecharts畫(huà)好看的餅狀圖

    這篇文章主要給大家介紹了關(guān)于如何利用pyecharts畫(huà)好看的餅狀圖的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Python使用socket_TCP實(shí)現(xiàn)小文件下載功能

    Python使用socket_TCP實(shí)現(xiàn)小文件下載功能

    這篇文章主要介紹了Python使用socket_TCP實(shí)現(xiàn)小文件下載功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Python通過(guò)psd-tools解析PSD文件

    Python通過(guò)psd-tools解析PSD文件

    這篇文章主要介紹了Python通過(guò)psd-tools解析PSD文件,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-06-06

最新評(píng)論