Personnalisation des messages d'erreur de la validation des balises Struct
Dans Gin, la validation des balises struct est utilisée pour garantir l'intégrité des données avant l'insertion de la base de données. L'erreur par défaut renvoyée est détaillée et peu informative pour l'utilisateur. Cet article décrit comment personnaliser le message d'erreur pour fournir une réponse plus significative.
Gin utilise le package go-playground/validator/v10 pour la validation. Les erreurs sont renvoyées sous la forme validator.ValidationErrors. Pour personnaliser le message, utilisez le package d'erreurs standard pour déballer l'erreur et accéder aux champs validator.FieldError.
Créez un modèle d'erreur (par exemple, ApiError) pour définir la structure de votre message d'erreur personnalisé. Par exemple :
type ApiError struct { Field string Msg string }
Dans votre gestionnaire, gérez l'erreur comme suit :
var u User err := c.BindQuery(&u); if err != nil { var ve validator.ValidationErrors if errors.As(err, &ve) { out := make([]ApiError, len(ve)) for i, fe := range ve { out[i] = ApiError{fe.Field(), msgForTag(fe.Tag())} } c.JSON(http.StatusBadRequest, gin.H{"errors": out}) } return }
Enfin, définissez une fonction d'assistance pour mapper les balises de validation aux messages personnalisés :
func msgForTag(tag string) string { switch tag { case "required": return "This field is required" case "email": return "Invalid email" } return "" }
En utilisant cette approche, les messages d'erreur seront personnalisés avec le nom du champ et un message personnalisé basé sur la balise de validation.
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!