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

Patricia Arquette
Freigeben: 2024-10-28 02:32:02
Original
789 Leute haben es durchsucht

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

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

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

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!

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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!