Maison >développement back-end >Golang >Comment le serveur « net/http » de Go gère-t-il le service de fichiers statiques sans répertoire racine fixe ?

Comment le serveur « net/http » de Go gère-t-il le service de fichiers statiques sans répertoire racine fixe ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-19 08:18:50807parcourir

How Does Go's `net/http` Server Handle Static File Serving Without a Fixed Root Directory?

Dévoilement du répertoire « Root » dans le serveur Web de Go

Dans le serveur Web net/http de Go, le concept de « racine » fixe le répertoire de service des fichiers est absent. Au lieu de cela, des gestionnaires sont utilisés pour répondre aux requêtes d'URL, offrant ainsi plus de flexibilité et de contrôle sur la livraison du contenu.

Mappage des gestionnaires

Un gestionnaire est une fonction qui traite une requête HTTP. et génère la réponse correspondante. Les URL sont associées à des gestionnaires utilisant les fonctions Handle() ou HandleFunc(). Lorsqu'une requête HTTP est reçue, le serveur fait correspondre l'URL demandée avec les gestionnaires enregistrés pour déterminer quel gestionnaire doit gérer la demande.

Fichiers statiques

Pour servir des fichiers statiques , Go fournit une fonction FileServer(). Il renvoie un gestionnaire qui sert les fichiers d'un répertoire "racine" spécifié. Ce répertoire peut être spécifié comme chemin absolu ou relatif.

Chemins absolus

Si un chemin absolu est utilisé avec FileServer(), le répertoire "racine" est sans ambiguïté .

Chemins relatifs

Chemins relatifs, cependant, dépendent du répertoire de travail actuel, qui est normalement le répertoire à partir duquel l'application a été démarrée. Par exemple :

http.Handle("/", http.FileServer(http.Dir("/tmp")))

Cela attribue un gestionnaire pour servir les fichiers du répertoire "/tmp", mappés à l'URL racine "/". Par conséquent, la réponse à "/mydoc.txt" sera le fichier "/tmp/mydoc.txt".

Mappage complexe

Des scénarios de cartographie plus complexes peuvent être réalisé avec la fonction StripPrefix(), qui modifie le chemin de l'URL de la requête avant qu'il ne soit transmis à FileServer(). Cela permet de servir des fichiers à partir d'un répertoire ou d'un chemin différent de celui de l'URL racine.

Exemple :

http.Handle("/tmpfiles/", http.StripPrefix("/tmpfiles/", http.FileServer(http.Dir("/tmp"))))

Cette configuration sert les fichiers de "/tmp" sous le chemin d'URL "/tmpfiles/" ; une requête pour "/tmpfiles/mydoc.txt" répondra avec le fichier "/tmp/mydoc.txt".

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