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 ?
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!