„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie kann ich 404-Fehler protokollieren, wenn ich „http.FileServer“ verwende, um statische Dateien in Go bereitzustellen?

Wie kann ich 404-Fehler protokollieren, wenn ich „http.FileServer“ verwende, um statische Dateien in Go bereitzustellen?

Veröffentlicht am 19.11.2024
Durchsuche:166

How can I log 404 errors when using `http.FileServer` to serve static files in Go?

Protokollierung von 404-Fehlern für Http.FileServer

Beim Bereitstellen statischer Dateien mit http.FileServer ist es oft wichtig, zu protokollieren, wenn eine Anfrage für eine Datei gestellt wird, die dies nicht tut existieren. Während http.FileServer selbst keine solche Protokollierung bereitstellt, können Sie dieses Ziel durch die Erweiterung seiner Funktionalität erreichen.

Um den von http.StripPrefix und http.FileServer zurückgegebenen Handler zu umschließen, erstellen Sie einen neuen http.Handler oder http. HandlerFunc. Der Wrapper ruft den Wrapper-Handler auf und überprüft den resultierenden HTTP-Antwortstatuscode. Wenn ein Fehler angezeigt wird (insbesondere HTTP 404 Not Found), kann das Ereignis protokolliert werden.

Da http.ResponseWriter das Lesen des Antwortstatuscodes nicht unterstützt, erstellen Sie einen Wrapper dafür (StatusRespWr). Dieser Wrapper speichert den Statuscode, wenn er geschrieben wird.

Der Code für den http.Handler-Wrapper sieht folgendermaßen aus:

func wrapHandler(h http.Handler) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        srw := &StatusRespWr{ResponseWriter: w}
        h.ServeHTTP(srw, r)
        if srw.status >= 400 { // 400  codes are error codes
            log.Printf("Error status code: %d when serving path: %s",
                srw.status, r.RequestURI)
        }
    }
}

Die Hauptfunktion kann den Dateiserver erstellen, umschließen und registrieren:

http.HandleFunc("/o/", wrapHandler(
    http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
panic(http.ListenAndServe(":8181", nil))

Beim Anfordern einer nicht vorhandenen Datei wird die folgende Ausgabe in der Konsole generiert:

2015/12/01 11:47:40 Error status code: 404 when serving path: /o/sub/b.txt2
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3