Maison > développement back-end > Golang > le corps du texte

Comment puis-je enregistrer les erreurs 404 lors de l'utilisation de « http.FileServer » pour servir des fichiers statiques dans Go ?

DDD
Libérer: 2024-10-31 01:42:29
original
967 Les gens l'ont consulté

How can I log 404 errors when using `http.FileServer` to serve static files in Go?

Consignation des erreurs 404 pour Http.FileServer

Lors du traitement de fichiers statiques à l'aide de http.FileServer, il est souvent important de se connecter lorsqu'une demande est faite pour un fichier qui ne fonctionne pas exister. Bien que http.FileServer lui-même ne fournisse pas une telle journalisation, l'extension de ses fonctionnalités vous permet d'atteindre cet objectif.

Pour envelopper le gestionnaire renvoyé par http.StripPrefix et http.FileServer, créez un nouveau http.Handler ou http. GestionnaireFunc. Le wrapper appellera le gestionnaire encapsulé et inspectera le code d’état de la réponse HTTP résultant. S'il indique une erreur (en particulier HTTP 404 Not Found), il peut enregistrer l'événement.

Étant donné que http.ResponseWriter ne prend pas en charge la lecture du code d'état de la réponse, créez un wrapper pour celui-ci (StatusRespWr). Ce wrapper stockera le code d'état lorsqu'il sera écrit.

Le code du wrapper http.Handler ressemble à ceci :

<code class="go">func wrapHandler(h http.Handler) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        srw := &StatusRespWr{ResponseWriter: w}
        h.ServeHTTP(srw, r)
        if srw.status >= 400 { // 400+ codes are error codes
            log.Printf("Error status code: %d when serving path: %s",
                srw.status, r.RequestURI)
        }
    }
}</code>
Copier après la connexion

La fonction principale peut créer le serveur de fichiers, l'envelopper , et enregistrez-le :

<code class="go">http.HandleFunc("/o/", wrapHandler(
    http.StripPrefix("/o", http.FileServer(http.Dir("/test")))))
panic(http.ListenAndServe(":8181", nil))</code>
Copier après la connexion

Lors de la demande d'un fichier inexistant, la sortie suivante sera générée dans la console :

2015/12/01 11:47:40 Error status code: 404 when serving path: /o/sub/b.txt2
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!