在 Gin 1.17 中,在数据库操作之前使用结构标签验证进行数据验证非常简单。虽然默认的错误消息很冗长,但可以自定义它们以提供更清晰的用户反馈。
Gin 使用 github.com/go-playground/validator/v10 包来实现验证。当验证失败时,它返回一个 validator.ValidationErrors 对象。此详细错误消息包含有关验证失败的每个字段的信息。
要获取自定义错误消息,您可以:
这是一个将验证错误转换为带有基于动态字段的错误的 JSON 响应的实现结构体:
type ApiError struct { Field string Msg string } func HandleValidationErrors(c *gin.Context, err error) { 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}) } } func msgForTag(tag string) string { switch tag { case "required": return "This field is required" case "email": return "Invalid email" } return "" }
在处理函数中,使用 HandleValidationErrors 处理验证错误:
func UserHandler(c *gin.Context) { var u User err := c.BindQuery(&u); if err != nil { HandleValidationErrors(c, err) return } // ... }
以上是如何使用 Struct 标签在 Gin 1.17 中自定义验证错误消息?的详细内容。更多信息请关注PHP中文网其他相关文章!