Gestion personnalisée des erreurs dans le package HTTP standard
Dans le package HTTP standard de Golang, lorsqu'une URL incorrecte est accédée, une "page 404" par défaut "Introuvable" s'affiche généralement. Pour personnaliser cette réponse et offrir une expérience plus conviviale, vous pouvez implémenter votre propre fonction de gestion des erreurs.
Solution pour le package HTTP pur :
Si vous êtes en utilisant uniquement le package net/http, vous pouvez créer une fonction errorHandler dédiée :
func errorHandler(w http.ResponseWriter, r *http.Request, status int) { w.WriteHeader(status) if status == http.StatusNotFound { fmt.Fprint(w, "custom 404") } }
Ensuite, vous pouvez enregistrer vos gestionnaires personnalisés et le errorHandler comme indiqué dans le code fourni :
http.HandleFunc("/", homeHandler) http.HandleFunc("/smth/", smthHandler) http.ListenAndServe(":12345", nil)
Solution pour le routeur Gorilla/Mux :
Si vous utilisez le routeur gorilla/mux, vous pouvez tirer parti de son fonctionnalité pour gérer les scénarios non trouvés :
func main() { r := mux.NewRouter() r.NotFoundHandler = http.HandlerFunc(notFound) }
Vous devrez ensuite implémenter la fonction notFound comme souhaité :
func notFound(w http.ResponseWriter, r *http.Request) { w.WriteHeader(http.StatusNotFound) fmt.Fprint(w, "custom 404") }
Gestion améliorée des erreurs :
L'exemple de code fourni illustre la gestion de base des erreurs, mais vous pouvez l'étendre pour gérer diverses erreurs HTTP et effectuer des actions supplémentaires , comme la journalisation ou l'envoi de notifications.
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!