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

Barbara Streisand
Freigeben: 2024-10-27 03:12:30
Original
797 Leute haben es durchsucht

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>
Nach dem Login kopieren

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
Nach dem Login kopieren

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!

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