Heim  >  Artikel  >  Backend-Entwicklung  >  Wie gehe ich mit Ausnahmen vom Typ „Datei nicht gefunden“ in einem Go Static File Server für Single-Page-Anwendungen um?

Wie gehe ich mit Ausnahmen vom Typ „Datei nicht gefunden“ in einem Go Static File Server für Single-Page-Anwendungen um?

Patricia Arquette
Patricia ArquetteOriginal
2024-10-28 02:32:02775Durchsuche

How to Handle File Not Found Exceptions in a Go Static File Server for Single-Page Applications?

Behandlung der Ausnahme „Datei nicht gefunden“ im statischen Go-Dateiserver

In einer Go-Anwendung nutzen Sie eine einseitige Webanwendung und stellen ihre Assets mithilfe einer statischen Datei bereit Dateiserver. Während der Server für die Bereitstellung vorhandener Assets im Stammverzeichnis gut funktioniert, gibt er den Fehler „404 Nicht gefunden“ aus, wenn eine angeforderte Datei nicht vorhanden ist.

Ihr Ziel ist es, das Verhalten des Servers zu ändern, um index.html für alle bereitzustellen Unbekannte URL. Dies ist von entscheidender Bedeutung, da Ihre Single-Page-Anwendung das Rendering basierend auf dem bereitgestellten HTML und JavaScript übernimmt.

Anpassen der Behandlung nicht gefundener Dateien

Dem von http.FileServer() bereitgestellten Standardhandler fehlen Anpassungsoptionen. einschließlich der Bearbeitung von 404 nicht gefundenen Antworten. Um diese Einschränkung zu beheben, verpacken wir den Handler und implementieren unsere Logik innerhalb des Wrappers.

Erstellen eines benutzerdefinierten HTTP-Antwortschreibers

Wir erstellen einen benutzerdefinierten http.ResponseWriter, der das Original umschließt Antwortschreiber. Dieser benutzerdefinierte Antwortschreiber wird:

  1. den Antwortstatus überprüfen und insbesondere nach einem 404-Statuscode suchen.
  2. Wenn ein 404-Statuscode erkannt wird, anstatt die Antwort an den Client zu senden , senden wir eine 302 Found-Umleitungsantwort an /index.html.

Unten finden Sie ein Beispiel für einen solchen benutzerdefinierten Antwortschreiber:

<code class="go">type NotFoundRedirectRespWr struct {
    http.ResponseWriter // Embed the base HTTP response writer
    status              int
}

func (w *NotFoundRedirectRespWr) WriteHeader(status int) {
    w.status = status // Store the status code
    if status != http.StatusNotFound {
        w.ResponseWriter.WriteHeader(status) // Proceed normally for non-404 statuses
    }
}

func (w *NotFoundRedirectRespWr) Write(p []byte) (int, error) {
    if w.status != http.StatusNotFound {
        return w.ResponseWriter.Write(p) // Proceed normally for non-404 statuses
    }
    return len(p), nil // Pretend that the data was successfully written, but discard it
}</code>

Einschließen des Standardhandlers

Als nächstes verpacken wir den von http.FileServer() zurückgegebenen Handler. Der Wrapper-Handler wird:

  1. den Standard-Handler aufrufen.
  2. Wenn der Standard-Handler den 404-Statuscode in unserem benutzerdefinierten Antwortschreiber festlegt, fängt dieser Wrapper die Antwort ab.
  3. Anstatt die 404-Antwort zu senden, wird die Anfrage an /index.html mit dem Status „302 Gefunden“ umgeleitet.

Hier ist ein Beispiel für den Wrapper-Handler:

<code class="go">func wrapHandler(h http.Handler) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        nfrw := &NotFoundRedirectRespWr{ResponseWriter: w}
        h.ServeHTTP(nfrw, r) // Call the default handler with our custom response writer
        if nfrw.status == 404 {
            log.Printf("Redirecting %s to index.html.", r.RequestURI)
            http.Redirect(w, r, "/index.html", http.StatusFound)
        }
    }
}</code>

Alles zusammenfügen

Nun verwenden Sie in Ihrer main()-Funktion den Wrapper-Handler, um das Verhalten des statischen Dateiservers zu ändern.

<code class="go">func main() {
    fs := wrapHandler(http.FileServer(http.Dir("."))) // Wrap the handler
    http.HandleFunc("/", fs)
    panic(http.ListenAndServe(":8080", nil)) // Start serving files with the custom handler
}</code>

Mit diesem Ansatz alles Anfragen an URLs, die nicht vorhandenen Dateien entsprechen, lösen eine Umleitung zu index.html aus. Ihre Single-Page-Anwendung funktioniert wie vorgesehen und rendert den entsprechenden Inhalt basierend auf dem bereitgestellten HTML und JavaScript.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Ausnahmen vom Typ „Datei nicht gefunden“ in einem Go Static File Server für Single-Page-Anwendungen um?. 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