You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 9 Next »
校验结果为一个Error对象指针。当数据规则校验成功时,校验方法返回的结果为nil。当数据规则校验失败时,返回的该对象是一个结构化的层级map,包含多个字段及其规则及对应错误信息,以便于接收端能够准确定位错误规则。相关数据结构及方法如下: https://godoc.org/github.com/gogf/gf/util/gvalid
Error
nil
map
// 校验错误信息: map[键名]map[规则名]错误信息 type ErrorMap map[string]map[string]string // 校验错误对象 type Error func (e *Error) Current() error func (e *Error) Error() string func (e *Error) FirstItem() (key string, messages map[string]string) func (e *Error) FirstRule() (rule string, err string) func (e *Error) FirstString() (err string) func (e *Error) Map() map[string]string func (e *Error) Maps() ErrorMap func (e *Error) String() string func (e *Error) Strings() (errs []string)
可以结合后续的示例理解这个数据结构。我们可以通过Maps()方法获得该原始错误信息数据结构map。但在大多数时候我们可以通过Error对象的其他方法来方便地获取特定的错误信息。
Maps()
大多数情况下,我们不关心具体出错的校验规则,可以使用String方法直接返回所有的错误信息即可。
String
简要说明:
获取校验结果的值可以通过多个校验结果方法获取,为让各位开发者有充分的理解,详细说明以下:
FirstItem
FirstRule
FirstString
Map
Maps
map[string]map[string]string
;
Strings
[]string
gerror.Current
我们可以看到,gvalid.Error实现了Current() error接口,因此可以通过gerror.Current方法获取它的第一条错误信息,这在接口校验失败时返回错误信息非常方便。我们来看一个示例:
gvalid.Error
Current() error
func (a *contentApi) DoUpdate(r *ghttp.Request) { var ( data *define.ContentApiDoUpdateReq serviceUpdateReq *define.ContentServiceUpdateReq ) if err := r.ParseForm(&data); err != nil { response.JsonExit(r, 1, gerror.Current(err).Error()) } if err := gconv.Struct(data, &serviceUpdateReq); err != nil { response.JsonExit(r, 1, err.Error()) } if err := service.Content.Update(r.Context(), serviceUpdateReq); err != nil { response.JsonExit(r, 1, err.Error()) } else { response.JsonExit(r, 0, "") } }
这里使用了gerror.Current(err).Error()来获取校第一条验错误信息。
gerror.Current(err).Error()
需要注意的是,数据校验时存在顺序性校验和非顺序性校验,这会对获取第一条错误信息的结果产生影响。关于顺序与非顺序性校验,具体可以参考后续章节介绍。