golan參數(shù)校驗(yàn)Validator
前言:
開(kāi)發(fā)接口的時(shí)候需要多前端提交的參數(shù)進(jìn)行參數(shù)校驗(yàn),如果提交的參數(shù)只有一個(gè)兩個(gè),這樣我們可以簡(jiǎn)單寫個(gè)if判斷,但是如果提交的參數(shù)比較多,通過(guò)if判斷就比較繁瑣了,在Go中有一個(gè)validator包可以通過(guò)反射結(jié)構(gòu)體struct的tag進(jìn)行參數(shù)校驗(yàn)
1.實(shí)踐
go get github.com/go-playground/validator/v10
定義結(jié)體:
type UserInfo struct {
ID int `validate:"gt=0"`
Age int `validate:"gt=0"`
Name string `validate:"required"`
Sex string `validate:"required"`
}
初始化結(jié)構(gòu)體并做參數(shù)校驗(yàn):
func InitUserInfo(id,age int,name,sex string) *UserInfo {
// new一個(gè)校驗(yàn)器
valid := validator.New()
// 初始化UserInfo
userInfo := &UserInfo{
ID: id,
Age: age,
Name:name,
Sex:sex,
}
if err := valid.Struct(userInfo);err != nil {
fmt.Println("參數(shù)校驗(yàn)不通過(guò)",err)
}
return userInfo
}
效果:
InitUserInfo(1,2,"kevin","男")// 參數(shù)校驗(yàn)通過(guò) InitUserInfo(0,2,"kevin","男")// 參數(shù)校驗(yàn)不通過(guò) Key: 'UserInfo.ID' Error:Field validation for 'ID' failed on the 'gt' tag InitUserInfo(1,2,"kevin","")// 參數(shù)校驗(yàn)不通過(guò) Key: 'UserInfo.Sex' Error:Field validation for 'Sex' failed on the 'required' tag
如參數(shù)校驗(yàn)不通過(guò),err中會(huì)包含不通過(guò)字段信息
1.1校驗(yàn)標(biāo)簽
-:跳過(guò)該字段,不測(cè)驗(yàn);
|:應(yīng)用多個(gè)束縛,只須要滿足其中一個(gè),例如rgb|rgba;
required:字段必須設(shè)置,不能為默認(rèn)值;
omitempty:如果字段未設(shè)置,則疏忽它


1.2字符串約束
excludesall:不包含參數(shù)中任意的UNICODE字符,例如excludesall=ab;excludesrune:不包含參數(shù)表示的 rune 字符,excludesrune=asong;startswith:以參數(shù)子串為前綴,例如startswith=hi;endswith:以參數(shù)子串為后綴,例如endswith=bye。contains=:包含參數(shù)子串,例如contains=email;containsany:包含參數(shù)中任意的 UNICODE 字符,例如containsany=ab;containsrune:包含參數(shù)表示的 rune 字符,例如`containsrune=asong;excludes:不包含參數(shù)子串,例如excludes=email;
1.3自定義校驗(yàn)器
在Gin中支持實(shí)現(xiàn)自定義校驗(yàn)標(biāo)簽
定義校驗(yàn)邏輯:
// sum不能大于10
func VerifySum(level validator.FieldLevel) bool {
if sum,ok := level.Field().Interface().(int);ok{
fmt.Println(sum)
if sum > 10 {
return false
}
return true
}
return false
}
注冊(cè)標(biāo)簽:
// 注冊(cè)
if v,ok := binding.Validator.Engine().(*validator.Validate); ok {
if err := v.RegisterValidation("sum",VerifySum);err != nil{
fmt.Println("參數(shù)校驗(yàn)標(biāo)簽注冊(cè)失敗")
}
fmt.Println("參數(shù)校驗(yàn)標(biāo)簽注冊(cè)成功")
}
應(yīng)用標(biāo)簽到結(jié)構(gòu)體上:
type TestSum struct {
Sum int `binding:"sum"`
}
測(cè)試:
func getSum(c *gin.Context) {
var b TestSum
b.Sum = cast.ToInt(c.Request.URL.Query().Get("sum"))
// 數(shù)據(jù)模型綁定查詢字符串驗(yàn)證
if err := c.ShouldBindWith(&b, binding.Query); err == nil {
c.JSON(http.StatusOK, gin.H{"message": "prams are valid!"})
} else {
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
}
}
func main() {
route := gin.Default()
// 注冊(cè)
if v,ok := binding.Validator.Engine().(*validator.Validate); ok {
if err := v.RegisterValidation("sum",VerifySum);err != nil{
fmt.Println("參數(shù)校驗(yàn)標(biāo)簽注冊(cè)失敗")
}
fmt.Println("參數(shù)校驗(yàn)標(biāo)簽注冊(cè)成功")
}
route.GET("/getSum", getSum)
route.Run(":8080")
}


附加:
Go中獲取標(biāo)簽值是通過(guò)反射進(jìn)行獲取的:
type TestSum struct {
Sum int `binding:"sum"`
}
// 獲取標(biāo)簽值:
var b TestSum
b_type := reflect.TypeOf(b)
fmt.Println(b_type.Field(0).Tag.Get("binding"))到此這篇關(guān)于golan參數(shù)校驗(yàn)Validator的文章就介紹到這了,更多相關(guān)go參數(shù)校驗(yàn)Validator內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語(yǔ)言字符串操作指南:簡(jiǎn)單易懂的實(shí)戰(zhàn)技巧
本文將介紹Go語(yǔ)言中字符串的實(shí)戰(zhàn)操作,通過(guò)本文的學(xué)習(xí),讀者將掌握Go語(yǔ)言中字符串的常用操作,為實(shí)際開(kāi)發(fā)提供幫助,需要的朋友可以參考下2023-10-10
Go語(yǔ)言操作mysql數(shù)據(jù)庫(kù)簡(jiǎn)單例子
這篇文章主要介紹了Go語(yǔ)言操作mysql數(shù)據(jù)庫(kù)簡(jiǎn)單例子,本文包含插入數(shù)據(jù)和查詢代碼實(shí)例,需要的朋友可以參考下2014-10-10
Golang Http請(qǐng)求返回結(jié)果處理
本文主要介紹了Golang Http請(qǐng)求返回結(jié)果處理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
Go語(yǔ)言實(shí)現(xiàn)棧與隊(duì)列基本操作學(xué)家
go語(yǔ)言中,并沒(méi)有棧與隊(duì)列相關(guān)的數(shù)據(jù)結(jié)構(gòu),但是我們可以借助切片來(lái)實(shí)現(xiàn)棧與隊(duì)列的操作;接下來(lái)我們一起實(shí)現(xiàn)棧與隊(duì)列基本操作,感興趣的可以了解一下2022-11-11
Go語(yǔ)言kube-scheduler深度剖析開(kāi)發(fā)之scheduler初始化
這篇文章主要介紹了Go語(yǔ)言kube-scheduler深度剖析開(kāi)發(fā)之scheduler初始化實(shí)現(xiàn)過(guò)程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
GoFrame基于性能測(cè)試得知grpool使用場(chǎng)景
這篇文章主要為大家介紹了GoFrame基于性能測(cè)試得知grpool使用場(chǎng)景示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06

