


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:
- den Antwortstatus überprüfen und insbesondere nach einem 404-Statuscode suchen.
- 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:
- den Standard-Handler aufrufen.
- Wenn der Standard-Handler den 404-Statuscode in unserem benutzerdefinierten Antwortschreiber festlegt, fängt dieser Wrapper die Antwort ab.
- 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!

Interfaces undPolymorphismingoenhanceCodereusibility und Mainainabability.1) DefineInterFacesAtherightabRactraction -Level.2) Verwenden vonInterfacesfordEpendencyInjeds.3) ProfilecodetomanagePerformancepacts.

TheInitfunctioningorunsautomatischbefestigungstoinitializepackagesandsetuptheenumgebungen

Schnittstellenkombinationen bauen komplexe Abstraktionen in der Go -Programmierung auf, indem sie Funktionen in kleine, fokussierte Schnittstellen zerlegen. 1) Leser, Schriftsteller und engere Schnittstellen definieren. 2) Erstellen Sie komplexe Typen wie Datei und Netzwerkstream, indem Sie diese Schnittstellen kombinieren. 3) Verwenden Sie die ProcessData -Funktion, um zu zeigen, wie diese kombinierten Schnittstellen umgehen. Dieser Ansatz verbessert die Code -Flexibilität, Testbarkeit und Wiederverwendbarkeit, aber es sollte darauf geachtet werden, übermäßige Fragmentierung und kombinatorische Komplexität zu vermeiden.

InitunctionsingoareAutomatisch beantragtBeforeThemaNFunctionAndarEsForforsetUpButComeWithAlhaldenges.1) Ausführungsorder: multipleInitfunctionsRunindeFinitionOrder

Artikel erläutert die Iteration durch Karten in Go, konzentriert sich auf sichere Praktiken, Änderungen von Einträgen und Leistungsüberlegungen für große Karten.

In dem Artikel wird das Erstellen und Manipulieren von Karten in GO, einschließlich Initialisierungsmethoden und Hinzufügen/Aktualisieren von Elementen, erläutert.

Der Artikel erörtert Unterschiede zwischen Arrays und Scheiben in Go und konzentriert sich auf Größe, Speicherzuweisung, Funktionsübergabe und Nutzungsszenarien. Arrays sind fest und stapelalloziert, während die Scheiben dynamisch, häufig zugeteilt und flexibler sind.

In dem Artikel wird das Erstellen und Initialisieren von Scheiben in GO erörtert, einschließlich der Verwendung von Literalen, der Make -Funktion und dem Schneiden vorhandener Arrays oder Scheiben. Es deckt auch die Slice -Syntax und die Bestimmung der Scheibenlänge und -kapazität ab.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool
