在 Go Gin 中自定义结构标记验证的错误消息
Gin 是一个流行的 Go Web 框架,使用 go-playground/validator/ v10 用于结构验证。当验证失败时,它通常会返回详细的错误消息。本文探讨如何自定义这些消息以提供更人性化的体验。
理解错误类型
Gin 的验证返回的错误是验证器。ValidationErrors 。此错误类型包含 validator.FieldErrors 的集合,每个都代表无效字段及其验证标记。
自定义错误消息
要自定义错误消息,我们可以使用 error.As 函数将 validator.ValidationErrors 转换为错误。转换后,我们可以访问各个 validator.FieldErrors 并根据所使用的验证标签构造自定义错误消息。
创建自定义错误模型
首先,我们定义自定义错误模型,例如:
type ApiError struct { Field string Msg string }
自定义验证错误消息标签
接下来,我们定义一个辅助函数来将验证标签映射到自定义错误消息:
func msgForTag(tag string) string { switch tag { case "required": return "This field is required" case "email": return "Invalid email" } return "" }
绑定和处理验证错误
在我们的处理函数中,我们可以将请求绑定到我们的结构并检查验证错误:
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 }
示例输出
使用此自定义错误处理,我们可以返回以下格式的 JSON 响应:
{ "errors": [ { "Field": "Number", "Msg": "This field is required" } ] }
这为用户提供了更加用户友好且信息丰富的错误响应。
以上是如何自定义 Go Gin 结构标签验证的错误消息?的详细内容。更多信息请关注PHP中文网其他相关文章!