Heim >Backend-Entwicklung >Golang >Wie protokolliere ich 404-Fehler bei Verwendung eines HTTP-Dateiservers?

Wie protokolliere ich 404-Fehler bei Verwendung eines HTTP-Dateiservers?

Barbara Streisand
Barbara StreisandOriginal
2024-10-27 03:12:30803Durchsuche

How to Log 404 Errors When Using HTTP File Server?

Protokoll 404-Status bei fehlenden Dateien mit HTTP-Dateiserver

Bei der Bereitstellung von Dateien über http.FileServer können Anfragen für nicht vorhandene Dateien zurückgegeben werden einen 404-Statuscode, ohne an der Serverkonsole angemeldet zu sein. Dies kann es schwierig machen, fehlende Dateien zu verfolgen und Fehler zu beheben.

Lösung

Um HTTP 404-Fehler zu protokollieren, verbessern Sie die Funktionalität der von http.StripPrefix() zurückgegebenen Handler. und http.FileServer():

  1. Verpacken Sie den ursprünglichen Handler in einen benutzerdefinierten Handler oder eine Handlerfunktion.
  2. Überschreiben Sie die WriteHeader()-Methode in einer neuen StatusRespWr-Struktur, die http.ResponseWriter umschließt . Dadurch können wir den HTTP-Statuscode erfassen.

Der umschlossene Handler ruft den ursprünglichen Handler auf und protokolliert HTTP 404- oder höhere Fehlercodes nach Erhalt der Antwort. Der folgende Beispielcode zeigt eine vollständige Implementierung:

<code class="go">type StatusRespWr struct {
    http.ResponseWriter
    status int
}

func (w *StatusRespWr) WriteHeader(status int) {
    w.status = status
    w.ResponseWriter.WriteHeader(status)
}

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 {
            log.Printf("Error status code: %d when serving path: %s", srw.status, r.RequestURI)
        }
    }
}

func main() {
    http.HandleFunc("/o/", wrapHandler(
        http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
    panic(http.ListenAndServe(":8181", nil))
}</code>

Wenn eine nicht vorhandene Datei angefordert wird, protokolliert der umschlossene Handler den folgenden Fehler:

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

Das obige ist der detaillierte Inhalt vonWie protokolliere ich 404-Fehler bei Verwendung eines HTTP-Dateiservers?. 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