Désinscription d'un gestionnaire dans net/http
Dans net/http, les gestionnaires peuvent être enregistrés dynamiquement dans des modèles d'URL spécifiques à l'aide de http.Handle fonction. Cependant, le multiplexeur par défaut ne fournit pas de mécanisme pour désenregistrer les gestionnaires.
Une approche pour désenregistrer un gestionnaire consiste à créer un multiplexeur personnalisé qui étend le type http.ServeMux standard. Ce multiplexeur personnalisé peut inclure une méthode de désenregistrement des gestionnaires. Par exemple, le code suivant définit un multiplexeur personnalisé qui ajoute une méthode Deregister :
type MyMux struct {
*http.ServeMux
mu sync.Mutex // Guards the m map
m map[string]http.Handler
}
func (mux *MyMux) Deregister(pattern string) error {
mux.mu.Lock()
defer mux.mu.Unlock()
if _, ok := mux.m[pattern]; !ok {
return errors.New("handler not registered")
}
delete(mux.m, pattern)
return nil
}
Une fois le multiplexeur personnalisé défini, il peut être utilisé pour gérer les requêtes. Par exemple :
mux := new(MyMux)
mux.Handle("/create", &factory)
srv := &http.Server{
Addr: "localhost:8080",
Handler: mux,
}
srv.ListenAndServe()
L'appel de la méthode Deregister sur le multiplexeur personnalisé empêchera le gestionnaire correspondant de traiter les demandes. Notez que le gestionnaire doit être enregistré à l'aide de la même instance de multiplexeur personnalisé pour que la désinscription soit effective.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3