Heim > Backend-Entwicklung > Golang > Wie kann ich in Go mit Gorilla Mux sowohl HTTP-Anfragen als auch -Antworten effektiv protokollieren?

Wie kann ich in Go mit Gorilla Mux sowohl HTTP-Anfragen als auch -Antworten effektiv protokollieren?

Susan Sarandon
Freigeben: 2024-12-03 00:06:14
Original
337 Leute haben es durchsucht

How Can I Effectively Log Both HTTP Requests and Responses in Go with Gorilla Mux?

HTTP-Antworten mit Go und Gorilla protokollieren

Beim Erstellen komplexer Webanwendungen mit Go und dem Gorilla-Web-Toolkit werden sowohl HTTP-Anfragen als auch -Antworten protokolliert ist für das Debuggen und Analysieren unerlässlich. Während das Protokollieren von Anfragen mit dem LoggingHandler von Gorilla unkompliziert ist, stellt das Protokollieren von Antworten eine Herausforderung dar.

Antworten protokollieren

Die bereitgestellte Lösung von Eric Broda protokolliert Antworten effektiv, tut dies jedoch nicht Senden Sie die Antwort an den Client. Hier ist eine modifizierte Version, die die Funktionalität des ursprünglichen Codes beibehält und gleichzeitig sicherstellt, dass die Antwort den Client erreicht:

func logHandler(fn http.HandlerFunc) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        x, err := httputil.DumpRequest(r, true)
        if err != nil {
            http.Error(w, fmt.Sprint(err), http.StatusInternalServerError)
            return
        }
        log.Println(fmt.Sprintf("%q", x))
        rec := httptest.NewRecorder()
        fn(rec, r)
        log.Println(fmt.Sprintf("%q", rec.Body))        

        // this copies the recorded response to the response writer
        for k, v := range rec.HeaderMap {
            w.Header()[k] = v
        }
        w.WriteHeader(rec.Code)
        rec.Body.WriteTo(w)
    }
}
Nach dem Login kopieren

Um diese Funktion zu nutzen, schließen Sie einfach Ihre Handler-Funktion mit logHandler ein:

http.HandleFunc("/", logHandler(myHandler))
Nach dem Login kopieren

Diese Änderung stellt sicher, dass sowohl Anfragen als auch Antworten protokolliert werden, während die Antwort weiterhin korrekt an den Client übermittelt wird.

Das obige ist der detaillierte Inhalt vonWie kann ich in Go mit Gorilla Mux sowohl HTTP-Anfragen als auch -Antworten effektiv protokollieren?. 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