Heim >Backend-Entwicklung >Golang >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?

DDD
DDDOriginal
2024-10-31 01:42:291014Durchsuche

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

Protokollieren 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:

<code class="go">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)
        }
    }
}</code>

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

<code class="go">http.HandleFunc("/o/", wrapHandler(
    http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
panic(http.ListenAndServe(":8181", nil))</code>

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

Das obige ist der detaillierte Inhalt vonWie kann ich 404-Fehler protokollieren, wenn ich „http.FileServer' verwende, um statische Dateien in Go bereitzustellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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