GoFrame数据校验之校验对象 | 校验结构体

简介: 这篇文章将会为大家介绍GoFrame数据校验中校验对象的知识点,包括:Validator对象常用方法的介绍、单数据校验、校验Map、校验结构体的示例

基本概念


数据校验组件提供了数据校验对象:用于数据校验统一的配置管理,支持我们便捷的进行链式操作。


方法介绍


type Validator
    func New() *Validator
    func (v *Validator) CheckMap(params interface{}) Error
    func (v *Validator) CheckStruct(object interface{}) Error
    func (v *Validator) CheckValue(value interface{}) Error
    func (v *Validator) Clone() *Validator
    func (v *Validator) Ctx(ctx context.Context) *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) Rules(rules interface{}) *Validator


简要说明


  1. New()方法用于创建一个新的校验对象。
  2. CheckValue/CheckMap/CheckStruct方法用于特定参数类型的数据校验,我们在项目开发中使用比较多的是CheckStruct,也建议大家使用CheckStruct
  3. Ctx()方法用于传递Context上下文变量。
  4. I18n()方法用于设置当前校验对象的I18N国际化组件,默认情况下,校验组件使用的是框架全局默认的i18n组件对象。
  5. Data()方法用于设置需要校验的数据集合,支持map类型或者struct类型。
  6. Rules()方法用于传递当前链式操作校验的自定义校验规则,支持使用[]string类型或者map类型。
  7. Messages()方法用于传递当前链式操作校验的自定义错误提示信息,往往使用map类型传递,具体看后续代码示例。


注意问题TIPS


在数据校验对象的CheckValue/CheckMap/CheckStruct方法中,不存在Context上下文变量参数,而是通过链式操作的Ctx方法来控制。

GoFrame的g模块中定义了Validator方法来快捷创建校验对象:官方也推荐我们使用g模块的g.Validator()方式来快捷创建一个校验对象。


链式操作


示例1:单数据校验


简单示例


err := g.Validator().Rules("min:60").Messages("考试不及格").CheckValue(16)
    fmt.Println(err.String()) //打印结果:考试不及格


进阶示例


package main
import (
   "fmt"
   "github.com/gogf/gf/frame/g"
)
func main() {
   data := g.Map{
      "password": "123", //这个的作用仅是定义了这个结构设置了默认值,并不代表着传入了值
   }
   //Data()中的参数是需要进行校验的数据集合,常用于map或者结构体类型。
   //CheckValue()是输入的参数
   err := g.Validator().Data(data).Rules("required-with:password").Messages("请输入确认密码").CheckValue("")
   if err != nil {
      fmt.Println("CheckValue传入为空时:" + err.String()) // 请输入确认密码
   } else {
      fmt.Println("CheckValue传入为空时:校验通过")
   }
   err = g.Validator().Data(data).Rules("required-with:password").Messages("请输入确认密码").CheckValue("1")
   if err != nil {
      fmt.Println("CheckValue传入不为空时:" + err.String()) // 请输入确认密码
   } else {
      fmt.Println("CheckValue传入不为空时:校验通过")
   }
}


进阶示例打印结果


微信图片_20221112231724.jpg


示例2:Map数据校验


params := map[string]interface{}{
  "passport":  "",
  "password":  "wangzhongyang",
  "password2": "zhongyang",
}
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).CheckMap(params)
if err != nil {
  g.Dump(err.Maps())
}


执行后,终端输出:


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


示例3:Struct数据校验


type User struct {
  Name string `v:"required#请输入用户姓名"`
  Type int    `v:"required#请选择用户类型"`
}
data := g.Map{
  "name": "wangzhongyang",
}
user := User{}
if err := gconv.Scan(data, &user); err != nil {
  panic(err)
}
err := g.Validator().Data(data).CheckStruct(user)
if err != nil {
  fmt.Println(err.Items()) //[map[Type:map[required:请选择用户类型]]]
}


相关文章
|
5月前
|
Java Spring 容器
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
详解java参数校验之:顺序校验、自定义校验、分组校验(@Validated @GroupSequence)
|
6月前
|
SQL API 数据库
优雅地进行入参数据校验:场景和处理方式
在日常的开发工作中,入参数据校验是确保程序健壮性的关键步骤之一,我们需要确保请求中的数据类型、格式和取值范围符合要求,以保证接口的安全性和稳定性,还有就是传递给方法或函数的数据需要满足一定的规则和要求,以保证程序的正常运行和数据的有效处理。那么本文就来分享一下在哪些场景下进行入参数据校验,并分享一些优雅的处理方式,以提高代码的可读性、扩展性和复用性。
101 3
优雅地进行入参数据校验:场景和处理方式
|
前端开发 Java 数据库
Spring Entity数据校验,分组校验,返回校验结果给前端
Spring Entity数据校验,分组校验,返回校验结果给前端
98 0
|
6月前
|
数据格式 Python
添加 常用校验方法,校验常见数据格式
添加 常用校验方法,校验常见数据格式
63 0
|
6月前
|
数据格式 Python
添加 自定义校验方法,让用户自定义校验规则
添加 自定义校验方法,让用户自定义校验规则
76 0
|
前端开发 JavaScript Java
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回
本篇将要学习 Spring Boot 统一功能处理模块,这也是 AOP 的实战环节 用户登录权限的校验实现接口 HandlerInterceptor + WebMvcConfigurer 异常处理使用注解 @RestControllerAdvice + @ExceptionHandler 数据格式返回使用注解 @ControllerAdvice 并且实现接口 @ResponseBodyAdvice
688 0
|
消息中间件 JavaScript 小程序
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回 下
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回 下
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回 下
|
前端开发 Java API
数据校验(前端数据校验、JSR303校验)
数据校验(前端数据校验、JSR303校验)
258 0
|
JavaScript 前端开发 小程序
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回 上
SpringBoot 统一功能处理:用户登录权限校验-拦截器、异常处理、数据格式返回 上