


So implementieren Sie Fehlerbehandlung und benutzerdefinierte Ausnahmen in FastAPI
So implementieren Sie Fehlerbehandlung und benutzerdefinierte Ausnahmen in FastAPI
Einführung:
FastAPI ist ein modernes Web-Framework auf Basis von Python. Aufgrund seiner hohen Leistung und schnellen Entwicklungsfunktionen wird es im Entwicklungsbereich immer beliebter. In tatsächlichen Anwendungen treten häufig Fehler und Ausnahmen auf. In diesem Artikel wird erläutert, wie Fehlerbehandlung und benutzerdefinierte Ausnahmen in FastAPI implementiert werden, um Entwicklern dabei zu helfen, Fehlersituationen in Anwendungen besser zu handhaben und zu verwalten.
FastAPI-Fehlerbehandlung:
FastAPI bietet einen integrierten Mechanismus zur Ausnahmebehandlung. Durch die Verwendung von Ausnahmehandlern oder Dekoratoren können wir Fehler in der Anwendung erfassen und behandeln. Hier ist ein einfaches Beispiel für die Fehlerbehandlung:
from fastapi import FastAPI app = FastAPI() @app.exception_handler(Exception) async def validation_exception_handler(request, exc): return JSONResponse(status_code=400, content={"message": "Bad request"}) @app.get("/users/{user_id}") async def read_user(user_id: int): if user_id <= 0: raise Exception("Invalid user id") return {"user_id": user_id}
Im obigen Beispiel verwenden wir den Dekorator @app.Exception_handler
, um einen globalen Ausnahmehandler zu definieren. Es akzeptiert zwei Parameter: Der erste Parameter ist der zu behandelnde Ausnahmetyp und der zweite Parameter ist eine Rückruffunktion, die zur Behandlung der Ausnahme verwendet wird. In diesem Beispiel fangen wir alle Exception
-Ausnahmen ab und geben eine JSONResponse
mit einer benutzerdefinierten Fehlermeldung zurück. @app.exception_handler
装饰器来定义了一个全局的异常处理器。它接受两个参数,第一个参数是要处理的异常类型,第二个参数是一个回调函数,用于处理异常。在这个例子中,我们捕获了所有的Exception
异常,并返回一个带有自定义错误消息的JSONResponse
。
当我们访问/users/{user_id}
这个路由时,如果传入的user_id
小于等于0,将会抛出一个自定义的异常。通过上面定义的全局的异常处理器,我们可以捕获并处理这个异常,并返回一个带有错误消息的JSONResponse
。
自定义异常:
除了使用内置的异常类型,我们还可以自定义异常类型,以便更好地区分和处理不同类型的错误。下面是一个自定义异常的示例:
class InvalidUserIdException(Exception): def __init__(self, user_id: int): self.user_id = user_id super().__init__("Invalid user id") @app.get("/users/{user_id}") async def read_user(user_id: int): if user_id <= 0: raise InvalidUserIdException(user_id) return {"user_id": user_id}
在上面的示例中,我们定义了一个名为InvalidUserIdException
的自定义异常类,它继承自Exception
类。我们还在构造函数中接受了一个user_id
参数,用于在异常消息中显示具体的用户ID。在路由处理函数中,当user_id
小于等于0时,我们抛出了这个自定义异常。
再次运行应用程序时,我们会看到与之前相同的结果。这是因为我们没有定义针对该自定义异常的特定异常处理程序。为了捕获和处理自定义异常,我们可以添加一个新的异常处理器:
@app.exception_handler(InvalidUserIdException) async def invalid_user_id_exception_handler(request, exc): return JSONResponse(status_code=400, content={"message": str(exc)})
在上面的示例中,我们添加了一个新的异常处理器,用于捕获InvalidUserIdException
异常。它与之前的全局异常处理器有相同的结构,只是处理逻辑不同。在这个处理器中,我们将异常消息转换为字符串,并返回一个带有错误消息的JSONResponse
。
这样,当我们访问/users/{user_id}
这个路由时,如果传入的user_id
小于等于0,将会抛出InvalidUserIdException
异常。通过特定的异常处理器,我们可以捕获并处理这个异常,并返回一个带有自定义错误消息的JSONResponse
/users/{user_id
zugreifen und die eingehende user_id
kleiner oder gleich 0 ist, wird eine benutzerdefinierte Ausnahme ausgelöst. Durch den oben definierten globalen Ausnahmehandler können wir diese Ausnahme abfangen und behandeln und eine JSONResponse
mit einer Fehlermeldung zurückgeben.
Benutzerdefinierte Ausnahmen:
rrreee
Im obigen Beispiel haben wir eine benutzerdefinierte Ausnahmeklasse mit dem NamenInvalidUserIdException
definiert, die von der Klasse Exception
erbt. Wir akzeptieren auch einen user_id
-Parameter im Konstruktor, um die spezifische Benutzer-ID in der Ausnahmemeldung anzuzeigen. Wenn in der Routing-Verarbeitungsfunktion user_id
kleiner oder gleich 0 ist, lösen wir diese benutzerdefinierte Ausnahme aus. - Wenn wir die Anwendung erneut ausführen, werden wir die gleichen Ergebnisse wie zuvor sehen. Dies liegt daran, dass wir für diese benutzerdefinierte Ausnahme keinen spezifischen Ausnahmehandler definiert haben. Um benutzerdefinierte Ausnahmen abzufangen und zu behandeln, können wir einen neuen Ausnahmehandler hinzufügen: rrreee
- Im obigen Beispiel haben wir einen neuen Ausnahmehandler zum Abfangen von
InvalidUserIdException
-Ausnahmen hinzugefügt. Es hat die gleiche Struktur wie der vorherige globale Ausnahmebehandler, die Verarbeitungslogik ist jedoch unterschiedlich. In diesem Handler konvertieren wir die Ausnahmemeldung in einen String und geben eineJSONResponse
mit der Fehlermeldung zurück.
/users/{user_id
zugreifen und die eingehende user_id
kleiner oder gleich 0 ist, kommt es zu einer InvalidUserIdException Code> wird ausgelöst, Code>Ausnahme. Mit einem bestimmten Ausnahmehandler können wir diese Ausnahme abfangen und behandeln und eine <code>JSONResponse
mit einer benutzerdefinierten Fehlermeldung zurückgeben. 🎜🎜Zusammenfassung: 🎜Durch die Verwendung des Fehlerbehandlungsmechanismus von FastAPI können wir Fehlersituationen in unseren Anwendungen besser behandeln und verwalten. Wir können einen globalen Ausnahmehandler verwenden, um alle Ausnahmen abzufangen und zu behandeln, oder wir können spezifische Ausnahmehandler definieren, um bestimmte Ausnahmetypen zu behandeln. Gleichzeitig können wir auch Ausnahmeklassen anpassen, um verschiedene Fehlertypen besser zu unterscheiden und zu behandeln und so die Lesbarkeit und Wartbarkeit des Codes zu verbessern. 🎜🎜Referenzlink: 🎜🎜🎜Offizielle FastAPI-Dokumentation: https://fastapi.tiangolo.com/tutorial/handling-errors/🎜🎜Offizielle Python-Dokumentation: https://docs.python.org/3/tutorial/errors. html🎜🎜Das obige ist der detaillierte Inhalt vonSo implementieren Sie Fehlerbehandlung und benutzerdefinierte Ausnahmen in FastAPI. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Verwenden Sie Middleware, um die Fehlerbehandlung in Go-Funktionen zu verbessern: Einführung in das Konzept der Middleware, die Funktionsaufrufe abfangen und bestimmte Logik ausführen kann. Erstellen Sie eine Fehlerbehandlungs-Middleware, die die Fehlerbehandlungslogik in eine benutzerdefinierte Funktion einbindet. Verwenden Sie Middleware, um Handlerfunktionen so zu umschließen, dass die Fehlerbehandlungslogik ausgeführt wird, bevor die Funktion aufgerufen wird. Gibt den entsprechenden Fehlercode basierend auf dem Fehlertyp zurück

In C++ behandelt die Ausnahmebehandlung Fehler ordnungsgemäß über Try-Catch-Blöcke. Zu den häufigsten Ausnahmetypen gehören Laufzeitfehler, Logikfehler und Fehler außerhalb der Grenzen. Nehmen Sie als Beispiel die Fehlerbehandlung beim Öffnen einer Datei. Wenn das Programm eine Datei nicht öffnen kann, löst es eine Ausnahme aus, gibt die Fehlermeldung aus und gibt den Fehlercode über den Catch-Block zurück, wodurch der Fehler behandelt wird, ohne das Programm zu beenden. Die Ausnahmebehandlung bietet Vorteile wie die Zentralisierung der Fehlerbehandlung, Fehlerweitergabe und Code-Robustheit.

Zu den besten Tools und Bibliotheken zur Fehlerbehandlung in PHP gehören: Integrierte Methoden: set_error_handler() und error_get_last() Toolkits von Drittanbietern: Whoops (Debugging und Fehlerformatierung) Dienste von Drittanbietern: Sentry (Fehlermeldung und -überwachung) Drittanbieter Bibliotheken: PHP-error-handler (benutzerdefinierte Fehlerprotokollierung und Stack-Traces) und Monolog (Fehlerprotokollierungshandler)

Die Fehlerbehandlung und -protokollierung im C++-Klassendesign umfasst: Ausnahmebehandlung: Ausnahmen abfangen und behandeln, wobei benutzerdefinierte Ausnahmeklassen verwendet werden, um spezifische Fehlerinformationen bereitzustellen. Fehlercode: Verwenden Sie eine Ganzzahl oder Aufzählung, um die Fehlerbedingung darzustellen und im Rückgabewert zurückzugeben. Behauptung: Überprüfen Sie Vor- und Nachbedingungen und lösen Sie eine Ausnahme aus, wenn sie nicht erfüllt sind. Protokollierung der C++-Bibliothek: Grundlegende Protokollierung mit std::cerr und std::clog. Externe Protokollierungsbibliotheken: Integrieren Sie Bibliotheken von Drittanbietern für erweiterte Funktionen wie Ebenenfilterung und Protokolldateirotation. Benutzerdefinierte Protokollklasse: Erstellen Sie Ihre eigene Protokollklasse, abstrahieren Sie den zugrunde liegenden Mechanismus und stellen Sie eine gemeinsame Schnittstelle zum Aufzeichnen verschiedener Informationsebenen bereit.

Benutzerdefinierte Ausnahmen werden zum Erstellen von Fehlermeldungen und zur Verarbeitungslogik verwendet. Zunächst müssen Sie Exception oder RuntimeException erben, um eine benutzerdefinierte Ausnahmeklasse zu erstellen. Anschließend können Sie die Methode getMessage() überschreiben, um die Ausnahmemeldung festzulegen. Ausnahmen werden durch das Schlüsselwort throw ausgelöst. Verwenden Sie Try-Catch-Blöcke, um benutzerdefinierte Ausnahmen zu behandeln. Dieser Artikel bietet einen praktischen Fall für das Parsen von Ganzzahleingaben und das Auslösen einer benutzerdefinierten InvalidInputException, wenn die Eingabe keine Ganzzahl ist.

In Go-Funktionen verwendet die asynchrone Fehlerbehandlung Fehlerkanäle, um Fehler von Goroutinen asynchron weiterzuleiten. Die spezifischen Schritte sind wie folgt: Erstellen Sie einen Fehlerkanal. Starten Sie eine Goroutine, um Vorgänge auszuführen und Fehler asynchron zu senden. Verwenden Sie eine Select-Anweisung, um Fehler vom Kanal zu empfangen. Behandeln Sie Fehler asynchron, z. B. das Drucken oder Protokollieren von Fehlermeldungen. Dieser Ansatz verbessert die Leistung und Skalierbarkeit von gleichzeitigem Code, da die Fehlerbehandlung den aufrufenden Thread nicht blockiert und die Ausführung abgebrochen werden kann.

Beim Testen von Go-Funktionseinheiten gibt es zwei Hauptstrategien für die Fehlerbehandlung: 1. Stellen Sie den Fehler als einen bestimmten Wert des Fehlertyps dar, der zur Bestätigung des erwarteten Werts verwendet wird. 2. Verwenden Sie Kanäle, um Fehler an die Testfunktion zu übergeben. Dies eignet sich zum Testen von gleichzeitigem Code. In einem praktischen Fall wird die Fehlerwertstrategie verwendet, um sicherzustellen, dass die Funktion bei negativer Eingabe 0 zurückgibt.

In Golang können Sie mit Fehler-Wrappern neue Fehler erstellen, indem Sie Kontextinformationen an den ursprünglichen Fehler anhängen. Dies kann verwendet werden, um die von verschiedenen Bibliotheken oder Komponenten ausgelösten Fehlertypen zu vereinheitlichen und so das Debuggen und die Fehlerbehandlung zu vereinfachen. Die Schritte lauten wie folgt: Verwenden Sie die Funktion „errors.Wrap“, um die ursprünglichen Fehler in neue Fehler umzuwandeln. Der neue Fehler enthält Kontextinformationen zum ursprünglichen Fehler. Verwenden Sie fmt.Printf, um umschlossene Fehler auszugeben und so mehr Kontext und Umsetzbarkeit bereitzustellen. Wenn Sie verschiedene Fehlertypen behandeln, verwenden Sie die Funktion „errors.Wrap“, um die Fehlertypen zu vereinheitlichen.
