package main
import (
"fmt"
"github.com/gogf/gf/frame/g"
"github.com/gogf/gf/util/gvalid"
)
// 自定义规则函数
func customRule(value interface{}, rule string, message string, params map[string]interface{}) error {
// 在这里编写自定义规则的逻辑
if intValue, ok := value.(int); ok {
if intValue%2 == 0 {
return nil
}
return fmt.Errorf("%s必须是偶数", params["field"])
}
return fmt.Errorf("%s必须是整数", params["field"])
}
func main() {
// 初始化GoFrame框架
g.Init()
// 注册自定义规则
gvalid.RegisterRule("customRule", customRule)
// 注册自定义错误信息
gvalid.RegisterError("customRule", "自定义错误信息:%s")
// 定义待验证的Map数据
data := g.Map{
"age": 19,
}
// 定义验证规则,使用自定义规则
rules := g.MapStrStr{
"age": "customRule", // 使用自定义规则
}
// 使用gvalid.CheckMap进行Map校验
if err := gvalid.CheckMap(data, rules, nil); err != nil {
fmt.Println("Map校验失败:", err)
return
}
// 输出验证成功信息
fmt.Println("Map校验成功!")
}
在这个例子中,我们注册了一个自定义规则函数customRule,并通过gvalid.RegisterRule注册这个规则。然后,我们通过gvalid.RegisterError注册了一个自定义的错误信息,将自定义错误信息关联到规则名customRule上。
接着,我们定义了一个待验证的Map数据data和验证规则rules,在规则中使用了刚刚注册的自定义规则。
最后,我们调用gvalid.CheckMap进行校验,由于字段值不为偶数,校验将失败并输出自定义的错误信息。
通过自定义错误信息,你可以提供更友好和符合业务场景的错误提示,使得错误信息更易于理解和处理。
转载请注明出处:http://www.zyzy.cn/article/detail/7590/GoFrame