Wie gehe ich mit Fehlern in der Gin-Middleware um: Ein zentraler Ansatz?

Susan Sarandon
Freigeben: 2024-11-05 04:42:02
Original
678 Leute haben es durchsucht

How to Handle Errors in Gin Middleware:  A Centralized Approach?

So behandeln Sie Fehler in einer Gin-Middleware

Einführung

Beim Erstellen von Webanwendungen mit dem Gin-Framework ist es üblich, Fehler innerhalb jeder Route zu behandeln Handler. Dies kann zu einem umständlichen und redundanten Ansatz führen, insbesondere bei der Behandlung mehrerer HTTP-Fehler. Gin bietet eine elegantere Lösung durch den Einsatz von Fehlerbehandlungs-Middleware.

Middleware-basierte Fehlerbehandlung

Anstatt Fehler in jeder Route explizit zu behandeln, können wir eine Middleware erstellen, die Fehler abfängt und bereitstellt eine zentrale Möglichkeit, damit umzugehen. Die Middleware-Funktion sollte die folgenden Schritte umfassen:

<code class="go">func ErrorHandler(c *gin.Context) {
    // Proceed to the next handler in the chain
    c.Next()

    // Iterate over the errors that occurred during the request handling
    for _, err := range c.Errors {
        // Log the error or perform any other necessary operations
        logger.Error(&quot;whoops&quot;, ...)

        // Send an HTTP response with the appropriate status (or -1 to omit overwriting)
        c.JSON(-1, /* error payload */)
    }
}</code>
Nach dem Login kopieren

Die Middleware wird dem Router mit der Use-Methode hinzugefügt:

<code class="go">router := gin.New()
router.Use(middleware.ErrorHandler)</code>
Nach dem Login kopieren

Innerhalb der Routenhandler, anstatt Fehler manuell zu behandeln, Wir können die Anfrage mit dem entsprechenden HTTP-Status abbrechen:

<code class="go">func (h *Handler) List(c *gin.Context) {
    movies, err := h.service.ListService()

    if err != nil {
        c.AbortWithError(http.StatusInternalServerError, err)
        return
    }

    c.JSON(http.StatusOK, movies)
}</code>
Nach dem Login kopieren

Umgang mit benutzerdefinierten Fehlern

In der Middleware können wir den ursprünglichen Fehler überprüfen, indem wir auf das Err-Feld des Typs gin.Error zugreifen :

<code class="go">for _, err := range c.Errors {
    switch err.Err {
        case ErrNotFound:
            c.JSON(-1, gin.H{&quot;error&quot;: ErrNotFound.Error()})
    }
    // etc...
}</code>
Nach dem Login kopieren

Fehlerakkumulation und -protokollierung

Der Vorteil der Verwendung einer Middleware besteht darin, dass wir während der Anforderungsbearbeitung mehrere Fehler akkumulieren können. Darüber hinaus können wir den Fehlern Kontextinformationen hinzufügen, z. B. Benutzer-ID, Anforderungs-URL und mehr. Diese Informationen können für eine detailliertere Protokollierung und Fehlerberichterstattung verwendet werden.

Fazit

Durch die Verwendung der Middleware-basierten Fehlerbehandlung in Gin können wir die Fehlerbehandlung zentralisieren und vereinfachen, die Lesbarkeit des Codes verbessern und verbessern Fehlerprotokollierungsfunktionen. Dieser Ansatz ist idiomatischer und bietet die Flexibilität, benutzerdefinierte Fehler zu behandeln und während des Anforderungslebenszyklus mehrere Fehler zu akkumulieren.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Fehlern in der Gin-Middleware um: Ein zentraler Ansatz?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage