Maison >développement back-end >Golang >Comment rediriger les erreurs 404 vers Index.html dans un serveur de fichiers Go Static ?

Comment rediriger les erreurs 404 vers Index.html dans un serveur de fichiers Go Static ?

DDD
DDDoriginal
2024-10-28 05:29:30663parcourir

How to Redirect 404 Errors to Index.html in a Go Static File Server?

Comment gérer une erreur de fichier manquant lors de l'utilisation d'un serveur de fichiers statiques ?

Lorsque vous utilisez la méthode FileServer pour servir des fichiers statiques à partir d'un répertoire local, tous les actifs sur la route racine est servie correctement. Par exemple, index.html et style.css sont servis sans aucun problème pour les requêtes adressées à myserverurl/index.html et myserverurl/styles.css. Cependant, si une requête est adressée à une route pour laquelle il n'existe pas de fichier correspondant, une erreur 404 est renvoyée.

Pour servir index.html pour toutes ces routes et afficher l'écran approprié, un gestionnaire personnalisé peut être créé qui enveloppe le gestionnaire FileServer.

Création du wrapper

Le gestionnaire wrapper crée un wrapper http.ResponseWriter qui est transmis au gestionnaire FileServer. Cet rédacteur de réponse wrapper inspecte le code d’état. S'il constate que le code d'état est 404, il n'envoie pas de réponse au client. Au lieu de cela, il envoie une redirection vers /index.html.

Voici un exemple de ce à quoi le wrapper http.ResponseWriter peut ressembler :

type NotFoundRedirectRespWr struct {
    http.ResponseWriter // We embed http.ResponseWriter
    status              int
}

func (w *NotFoundRedirectRespWr) WriteHeader(status int) {
    w.status = status // Store the status for our own use
    if status != http.StatusNotFound {
        w.ResponseWriter.WriteHeader(status)
    }
}

func (w *NotFoundRedirectRespWr) Write(p []byte) (int, error) {
    if w.status != http.StatusNotFound {
        return w.ResponseWriter.Write(p)
    }
    return len(p), nil // Lie that we successfully written it
}

Le gestionnaire FileServer est enveloppé à l'aide de ce wrapper. :

func wrapHandler(h http.Handler) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        nfrw := &NotFoundRedirectRespWr{ResponseWriter: w}
        h.ServeHTTP(nfrw, r)
        if nfrw.status == 404 {
            log.Printf("Redirecting %s to index.html.", r.RequestURI)
            http.Redirect(w, r, "/index.html", http.StatusFound)
        }
    }
}

Le gestionnaire encapsulé est ensuite enregistré pour répondre aux requêtes :

func main() {
    fs := wrapHandler(http.FileServer(http.Dir(".")))
    http.HandleFunc("/", fs)
    panic(http.ListenAndServe(":8080", nil))
}

Tenter d'interroger un fichier inexistant comme /a.txt3 ou favicon.ico entraînera une erreur 404 et la requête étant redirigée vers /index.html.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn