Struct
校验常使用以下链式操作方式:
g.Validator().Data(object).Run(ctx)
在开始介绍Struct
参数类型校验之前,我们来介绍一下常用的gvalid tag
规则。规则如下:
[属性别名@]校验规则[#错误提示]
其中:
struct
属性的别名,同时校验后返回的error
对象中的也将使用该别名返回。例如在处理请求表单时比较有用,因为表单的字段名称往往和struct
的属性名称不一致。大部分场景下不需要设置属性别名,默认直接使用属性名称即可。 required|between:1,100
。 package main
import (
"github.com/GOgf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
type User struct {
Uid int `v:"uid @integer|min:1#|请输入用户ID"`
Name string `v:"name @required|length:6,30#请输入用户名称|用户名称长度非法"`
Pass1 string `v:"password1@required|password3"`
Pass2 string `v:"password2@required|password3|same:Pass1#|密码格式不合法|两次密码不一致,请重新输入"`
}
func main() {
var (
ctx = gctx.New()
user = &User{
Name: "john",
Pass1: "Abc123!@#",
Pass2: "123",
}
)
err := g.Validator().Data(user).Run(ctx)
if err != nil {
g.Dump(err.Items())
}
}
可以看到,我们可以对在struct
定义时使用了gvalid
的gvalid tag
来绑定校验的规则及错误提示信息。在此示例代码中,same:password1
规则同使用same:Pass1
规则是一样的效果。也就是说,在数据校验中,可以同时使用原有的struct
属性名称,也可以使用别名。但是,返回的结果中只会使用别名返回,这也是别名最大的用途。此外,在对struct
对象进行校验时,也可以传递校验或者和错误提示参数,这个时候会覆盖struct
在定义时绑定的对应参数。
以上示例执行后,输出结果为:
[
{
"uid": {
"min": "请输入用户ID",
},
},
{
"name": {
"length": "用户名称长度非法",
},
},
{
"password2": {
"password3": "密码格式不合法",
},
},
]
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
func main() {
type User struct {
Age int
Name string
}
var (
ctx = gctx.New()
user = User{Name: "john"}
rules = map[string]string{
"Name": "required|length:6,16",
"Age": "between:18,30",
}
messages = map[string]interface{}{
"Name": map[string]string{
"required": "名称不能为空",
"length": "名称长度为{min}到{max}个字符",
},
"Age": "年龄为18到30周岁",
}
)
err := g.Validator().Rules(rules).Messages(messages).Data(user).Run(ctx)
if err != nil {
g.Dump(err.Maps())
}
}
在以上示例中,Age
属性由于默认值0
的存在,因此会引起required
规则的失效,因此这里没有使用required
规则而是使用between
规则来进行校验。示例代码执行后,终端输出:
{
"Age": {
"between": "年龄为18到30周岁"
},
"Name": {
"length": "名称长度为6到16个字符"
}
}
支持递归的结构体校验,即如果属性也是结构体(也支持嵌套结构体(embedded
)),那么将会自动将该属性执行递归校验。使用示例:
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
func main() {
type Pass struct {
Pass1 string `valid:"password1@required|same:password2#请输入您的密码|您两次输入的密码不一致"`
Pass2 string `valid:"password2@required|same:password1#请再次输入您的密码|您两次输入的密码不一致"`
}
type User struct {
Pass
Id int
Name string `valid:"name@required#请输入您的姓名"`
}
var (
ctx = gctx.New()
user = &User{
Name: "john",
Pass: Pass{
Pass1: "1",
Pass2: "2",
},
}
)
err := g.Validator().Data(user).Run(ctx)
g.Dump(err.Maps())
}
或者属性为嵌套结构体(embedded
)的场景:
package main
import (
"github.com/gogf/gf/v2/frame/g"
"github.com/gogf/gf/v2/os/gctx"
)
func main() {
type Pass struct {
Pass1 string `valid:"password1@required|same:password2#请输入您的密码|您两次输入的密码不一致"`
Pass2 string `valid:"password2@required|same:password1#请再次输入您的密码|您两次输入的密码不一致"`
}
type User struct {
Id int
Name string `valid:"name@required#请输入您的姓名"`
Pass Pass
}
var (
ctx = gctx.New()
user = &User{
Name: "john",
Pass: Pass{
Pass1: "1",
Pass2: "2",
},
}
)
err := g.Validator().Data(user).Run(ctx)
g.Dump(err.Maps())
}
执行后,终端输出:
{
"password1": {
"same": "您两次输入的密码不一致",
},
"password2": {
"same": "您两次输入的密码不一致",
},
}
文章题目:创新互联GoFrame教程:GoFrameStruct校验-基本使用
网站网址:http://www.csdahua.cn/qtweb/news46/425346.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网