gin自定义验证器+中文翻译

1、说明

gin官网自定义验证器给的例子相对比较简单,主要是语法级别,便于入门学习,并且没有给出翻译相关的处理,因此在这里记录一下通用一点的自定义验证器+中文翻译的代码,可以直接在往后的go-web项目直接使用

2、global.go

// Package global 当前包存放全局的变量,便于项目所有包使用
package global

import (
	"net/http"
	"strings"

	"github.com/gin-gonic/gin"
	ut "github.com/go-playground/universal-translator"
	"github.com/go-playground/validator/v10"
)

/****************************** 全局变量 ****************************/
var (
	// Trans 全局的翻译器
	Trans ut.Translator
)

/****************************** 辅助函数 ****************************/

// removeTopStruct 移除打印的错误信息中的结构体包前缀
func removeTopStruct(fields map[string]string) map[string]string {
   
   
	rsp := map[string]string{
   
   }
	for field, err := range fields {
   
   
		rsp[field[strings.Index(field, ".")+1:]] = err
	}
	return rsp
}

// HandlerValidatorError 处理校验错误响应
func HandlerValidatorError(c *gin.Context, err error) {
   
   
	errs, ok := err.(validator.ValidationErrors)
	if !ok {
   
   
		c.JSON(http.StatusOK, gin.H{
   
   
			"msg": err.Error(),
		})
		return
	}
	c.JSON(http.StatusBadRequest, gin.H{
   
   
		"error": removeTopStruct(errs.Translate(Trans)),
	})
	return
}

3、validator.go

package validator

import (
	"fmt"
Gin中进行跨字段验证,可以通过自定义验证方法来实现。Gin的验证主要基于`validator`库,跨字段验证需要考虑一个字段的值依赖于另一个字段的情况。 ### 跨字段验证方法 1. **自定义验证函数**:利用`binding.Validator.Engine().(*validator.Validate).RegisterValidation`方法注册自定义验证函数,在函数中编写跨字段验证逻辑。 2. **在结构体标签中使用自定义验证规则**:在结构体字段的`binding`标签里使用自定义验证规则名。 ### 示例代码 ```go package main import ( "fmt" "github.com/gin-gonic/gin" "github.com/go-playground/validator/v10" "net/http" ) // 自定义跨字段验证函数,验证 endDate 是否大于 startDate func validateDateRange(fl validator.FieldLevel) bool { // 获取结构体实例 structObj := fl.Top().Interface() // 断言结构体类型 if req, ok := structObj.(PostParams); ok { // 比较 startDate 和 endDate return req.EndDate > req.StartDate } return false } // 定义请求参数结构体 type PostParams struct { StartDate int `json:"startDate" binding:"required"` EndDate int `json:"endDate" binding:"required,dateRange"` } func main() { r := gin.Default() // 将自定义的校验方法注册到 validator 中 if v, ok := gin.BindingValidator().(*validator.Validate); ok { v.RegisterValidation("dateRange", validateDateRange) } r.POST("/testBind", func(c *gin.Context) { var p PostParams err := c.ShouldBindJSON(&p) fmt.Printf("p: %v\n", p) if err != nil { fmt.Println(err) c.JSON(http.StatusBadRequest, gin.H{ "msg": "日期范围验证失败", "data": gin.H{}, }) } else { c.JSON(http.StatusOK, gin.H{ "msg": "成功了", "data": p, }) } }) r.Run(":8080") } ``` 在上述示例中,定义了`PostParams`结构体,其中`EndDate`字段使用了自定义的`dateRange`验证规则。通过`validateDateRange`函数实现了跨字段验证,确保`EndDate`大于`StartDate`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值