Le langage Go est un langage de programmation rapide et facile à utiliser avec une gestion efficace de la mémoire et de bonnes fonctionnalités de concurrence. Le package net/http dans sa bibliothèque standard fournit l'implémentation du client et du serveur HTTP, et fournit également de nombreuses fonctions liées à HTTP. Parmi elles, la fonction NewServeMux est une fonction très couramment utilisée. Elle permet de créer un routeur de requêtes HTTP et de lier le routeur au serveur HTTP. Cet article fournira une explication détaillée de la fonction NewServeMux dans le package net/http et fournira des exemples de code spécifiques.
La fonction NewServeMux est définie comme suit :
func NewServeMux() *ServeMux
Cette fonction renvoie un nouvel objet ServeMux, qui implémente l'interface http.Handler et peut donc être utilisé comme point d'entrée principal du serveur HTTP.
ServeMux est un type de structure défini comme suit :
type ServeMux struct {
// contains filtered or unexported fields
}
La structure ServeMux implémente l'interface http.Handler, elle peut donc gérer les requêtes et les réponses HTTP. La structure ServeMux contient une table de mappage en interne pour acheminer les requêtes vers différentes fonctions de traitement. Lorsque le serveur HTTP reçoit une requête, il fera correspondre le chemin de la requête avec la table de mappage dans ServeMux, puis acheminera la requête vers la fonction de traitement correspondante.
Voici un exemple simple de serveur HTTP qui utilise la fonction NewServeMux pour créer un routeur de requêtes et lier le routeur au serveur :
package main
import (
"fmt" "net/http"
)
func main() {
mux := http.NewServeMux() mux.HandleFunc("/hello", func(w http.ResponseWriter, r *http.Request) { fmt.Fprintln(w, "Hello, World!") }) server := http.Server{ Addr: ":8080", Handler: mux, } err := server.ListenAndServe() if err != nil { fmt.Println(err) }
}
Dans l'exemple ci-dessus, nous avons créé un routeur de requêtes nommé mux en appelant la fonction NewServeMux. Nous utilisons ensuite la fonction mux.HandleFunc pour acheminer la requête vers la fonction de gestionnaire sur le chemin "/hello". La fonction handleRequest sera appelée lorsqu'une requête sur le chemin "/hello" est reçue et la chaîne "Hello, World!" sera envoyée à la réponse HTTP. Enfin, nous créons un objet serveur HTTP nommé server et le lions à la variable mux, de sorte que lorsque le serveur HTTP reçoit une requête, il utilise la variable mux pour acheminer la requête vers la fonction handleRequest.
Notez que la fonction NewServeMux renvoie un pointeur vers l'objet ServeMux, nous devons donc utiliser la variable mux pour référencer l'objet. De plus, nous devons également utiliser la fonction mux.HandleFunc pour acheminer la requête vers la fonction de traitement des requêtes. Cette fonction accepte une chaîne et une fonction de type http.HandlerFunc comme paramètres, où le paramètre string représente le chemin de la requête et le paramètre function représente la fonction de traitement de la requête. Dans l'exemple ci-dessus, nous utilisons une fonction anonyme comme implémentation de la fonction handleRequest.
Résumé :
Cet article fournit une interprétation détaillée de la fonction NewServeMux dans le package net/http et fournit des exemples de code spécifiques. La fonction NewServeMux crée un routeur de requêtes HTTP et lie le routeur au serveur HTTP. L'utilisation de la fonction NewServeMux peut rendre le code du serveur HTTP plus modulaire et plus facile à maintenir. Afin d'utiliser correctement la fonction NewServeMux, nous devons comprendre les détails d'implémentation de ServeMux et utiliser la fonction mux.HandleFunc pour acheminer la requête vers la fonction de gestionnaire appropriée.
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!