创新互联GoFrame教程:GoFrame 数据校验-校验对象

校验对象

数据校验组件提供了数据校验对象,用于数据校验的统一的配置管理、便捷的链式操作。

成都创新互联-专业网站定制、快速模板网站建设、高性价比泸州网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式泸州网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖泸州地区。费用合理售后完善,10余年实体公司更值得信赖。

接口文档: https://pkg.GO.dev/github.com/gogf/gf/v2/util/gvalid

type Validator 
    func New() *Validator
    func (v *Validator) Assoc(assoc interface{}) *Validator
    func (v *Validator) Bail() *Validator
    func (v *Validator) Ci() *Validator
    func (v *Validator) Clone() *Validator
    func (v *Validator) Data(data interface{}) *Validator
    func (v *Validator) I18n(i18nManager *gi18n.Manager) *Validator
    func (v *Validator) Messages(messages interface{}) *Validator
    func (v *Validator) RuleFunc(rule string, f RuleFunc) *Validator
    func (v *Validator) RuleFuncMap(m map[string]RuleFunc) *Validator
    func (v *Validator) Rules(rules interface{}) *Validator
    func (v *Validator) Run(ctx context.Context) Error

简要说明:

  1. New​方法用于创建一个新的校验对象。
  2. Assoc​用于关联数据校验。
  3. Bail​方法用于设定只要后续的多个校验中有一个规则校验失败则停止校验立即返回错误结果。
  4. Ci​方法用于设置需要比较数值的规则时,不区分字段的大小写。
  5. Run​方法对给定规则和信息的数据进行校验操作。
  6. I18n​方法用于设置当前校验对象的​I18N​国际化组件。默认情况下,校验组件使用的是框架全局默认的​i18n​组件对象。
  7. Data​方法用于传递需要联合校验的数据集合,往往传递的是​map​类型或者​struct​类型。
  8. Rules​方法用于传递当前链式操作校验的自定义校验规则,往往使用​[]string​类型或者​map​类型。
  9. Messages​方法用于传递当前链式操作校验的自定义错误提示信息,往往使用​map​类型传递。

由于数据校验对象也是一个非常常用的对象,因此​g​模块中定义了​Validator​方法来快捷创建校验对象。大部分场景下我们推荐使用​g​模块的​g.Validator()​方式来快捷创建一个校验对象。

使用示例

单数据校验

var (
	err error
	ctx = gctx.New()
)
err = g.Validator().
	Rules("min:18").
	Data(16).
	Messages("未成年人不允许注册哟").
	Run(ctx)
fmt.Println(err.Error())

// Output:
// 未成年人不允许注册哟
var (
	err  error
	ctx  = gctx.New()
	data = g.Map{
		"password": "123",
	}
)

err = g.Validator().Data("").Assoc(data).
	Rules("required-with:password").
	Messages("请输入确认密码").
	Run(ctx)

fmt.Println(err.Error())

Struct数据校验

type User struct {
	Name string `v:"required#请输入用户姓名"`
	Type int    `v:"required#请选择用户类型"`
}
var (
	err  error
	ctx  = gctx.New()
	user = User{}
	data = g.Map{
		"name": "john",
	}
)
if err = gconv.Scan(data, &user); err != nil {
	panic(err)
}
err = g.Validator().Assoc(data).Data(user).Run(ctx)
if err != nil {
	fmt.Println(err.(gvalid.Error).Items())
}

// Output:
// [map[Type:map[required:请选择用户类型]]]

Map数据校验

params := map[string]interface{}{
	"passport":  "",
	"password":  "123456",
	"password2": "1234567",
}
rules := map[string]string{
	"passport":  "required|length:6,16",
	"password":  "required|length:6,16|same:password2",
	"password2": "required|length:6,16",
}
messages := map[string]interface{}{
	"passport": "账号不能为空|账号长度应当在{min}到{max}之间",
	"password": map[string]string{
		"required": "密码不能为空",
		"same":     "两次密码输入不相等",
	},
}
err := g.Validator().Messages(messages).Rules(rules).Data(params).Run(gctx.New())
if err != nil {
	g.Dump(err.Maps())
}

执行后,终端输出:

{
    "passport": {
        "length": "账号长度应当在6到16之间",
        "required": "账号不能为空"
    },
    "password": {
        "same": "两次密码输入不相等"
    }
}

当前标题:创新互联GoFrame教程:GoFrame 数据校验-校验对象
网页链接:http://www.mswzjz.cn/qtweb/news44/267644.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能