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.
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.
Wir erstellen einen benutzerdefinierten http.ResponseWriter, der das Original umschließt Antwortschreiber. Dieser benutzerdefinierte Antwortschreiber wird:
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>
Als nächstes verpacken wir den von http.FileServer() zurückgegebenen Handler. Der Wrapper-Handler wird:
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>
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!