组件支持的基础认证方式:
- 大于(Gt)
- 大于等于(Ge)
- 小于(Lt)
- 小于等于(Le)
- 不等于(Ne)
- 等于(Eq)
- 非空(NotEmpty)
- 日期格式(IsDateType)
- 密码格式(IsPassword)
func init() {
RegisterVerifies([]Func{
{
Name: "lt",
Description: "长度或值不在合法范围",
CallParam: Lt,
},
{
Name: "gt",
Description: "长度或值不在合法范围",
CallParam: Gt,
},
{
Name: "ge",
Description: "长度或值不在合法范围",
CallParam: Ge,
},
{
Name: "le",
Description: "长度或值不在合法范围",
CallParam: Le,
},
{
Name: "eq",
Description: "长度或值不在合法范围",
CallParam: Eq,
},
{
Name: "ne",
Description: "长度或值不在合法范围",
CallParam: Ne,
},
{
Name: "password",
Description: "密码格式不正确",
Call: IsPassword,
},
{
Name: "mobile",
Description: "手机号码格式认证失败",
Call: IsMobilePhone,
},
{
Name: "notEmpty",
Description: "字段不能为空",
Call: NotEmpty,
},
{
Name: "date",
Description: "日期格式不准确",
CallParam: IsDateType,
},
})
}
type Student struct {
Name string `verify:"notEmpty"`
Age int `verify:"gt(5),le(8)"`
Class string `verify:"eq(7)"`
CreateTime string `verify:"date(2006-01-02|2006/01/02)"`
UpdateTime string `verify:"date(2006-01-02|2006/01/02)"`
Book []string `verify:"gt(0)"`
Password string `verify:"password"`
Mobile string `verify:"mobile"`
}
func TestVerify(t *testing.T) {
err := Verify(Student{
Name: "name",
Age: 8,
Class: "testnam",
CreateTime: "2018/05/05",
UpdateTime: "2018-05-05",
Book: []string{"book"},
Password: "pasab145",
Mobile: "18010058148",
Email: "597410004@qq.com",
})
}
- 必须在
init()
方法中注册需要使用的认证方式 - 注册结构体说明:
name
对应tag
description
表示认证错误后提示信息CallParam
表示该认证方式需要参数Call
表示该认证方式不需要参数
- 框架分为参数调用和非参数调用两种方式,参数使用
()
表示,例:gt(2)
- 框架支持多种认证方式同时使用,比如:
- 需要一个数字大于3小于20,则
tag
中用,
分隔开,例:gt(3),lt(20)
; - 需要多个日期格式认证使用
|
分隔开,例:date(2006-01-02|2006/01/02)
- 需要一个数字大于3小于20,则
- 定义认证方式
- 注册该认证方式
- 在字段中添加
tag
- 样例:
// 定义一个认证email的方法
func email(v interface{}) bool {
value := v.(reflect.Value)
if ok, _ := regexp.MatchString("^\\w+([-+.]\\w+)*@\\w+([-.]\\w+)*\\.\\w+([-.]\\w+)*$", value.String()); !ok {
return false
}
return true
}
// 注册认证方法
RegisterVerify(Func{
Name: "email",
Description: "邮箱格式不正确",
Call: email,
})
// 使用
type Email struct{
Email string `verify:"email"`
}
1、支持根据结构定义导出顺序
type Person struct {
Name string `json:"name" xlsx:"name:名称,index:2"`
Age int64 `json:"age" xlsx:"name:年龄,index:1"`
Sex int64 `json:"sex" xlsx:"-"`
}
其中name表示单元格名称 index表示单元格顺序