golan參數(shù)校驗Validator
前言:
開發(fā)接口的時候需要多前端提交的參數(shù)進(jìn)行參數(shù)校驗,如果提交的參數(shù)只有一個兩個,這樣我們可以簡單寫個if判斷,但是如果提交的參數(shù)比較多,通過if判斷就比較繁瑣了,在Go中有一個validator
包可以通過反射結(jié)構(gòu)體struct
的tag
進(jìn)行參數(shù)校驗
1.實踐
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ù)校驗:
func InitUserInfo(id,age int,name,sex string) *UserInfo { // new一個校驗器 valid := validator.New() // 初始化UserInfo userInfo := &UserInfo{ ID: id, Age: age, Name:name, Sex:sex, } if err := valid.Struct(userInfo);err != nil { fmt.Println("參數(shù)校驗不通過",err) } return userInfo }
效果:
InitUserInfo(1,2,"kevin","男")// 參數(shù)校驗通過 InitUserInfo(0,2,"kevin","男")// 參數(shù)校驗不通過 Key: 'UserInfo.ID' Error:Field validation for 'ID' failed on the 'gt' tag InitUserInfo(1,2,"kevin","")// 參數(shù)校驗不通過 Key: 'UserInfo.Sex' Error:Field validation for 'Sex' failed on the 'required' tag
如參數(shù)校驗不通過,err中會包含不通過字段信息
1.1校驗標(biāo)簽
-:跳過該字段,不測驗;
|:應(yīng)用多個束縛,只須要滿足其中一個,例如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自定義校驗器
在Gin中支持實現(xiàn)自定義校驗標(biāo)簽
定義校驗邏輯:
// 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 }
注冊標(biāo)簽:
// 注冊 if v,ok := binding.Validator.Engine().(*validator.Validate); ok { if err := v.RegisterValidation("sum",VerifySum);err != nil{ fmt.Println("參數(shù)校驗標(biāo)簽注冊失敗") } fmt.Println("參數(shù)校驗標(biāo)簽注冊成功") }
應(yīng)用標(biāo)簽到結(jié)構(gòu)體上:
type TestSum struct { Sum int `binding:"sum"` }
測試:
func getSum(c *gin.Context) { var b TestSum b.Sum = cast.ToInt(c.Request.URL.Query().Get("sum")) // 數(shù)據(jù)模型綁定查詢字符串驗證 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() // 注冊 if v,ok := binding.Validator.Engine().(*validator.Validate); ok { if err := v.RegisterValidation("sum",VerifySum);err != nil{ fmt.Println("參數(shù)校驗標(biāo)簽注冊失敗") } fmt.Println("參數(shù)校驗標(biāo)簽注冊成功") } route.GET("/getSum", getSum) route.Run(":8080") }
附加:
Go中獲取標(biāo)簽值是通過反射進(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ù)校驗Validator的文章就介紹到這了,更多相關(guān)go參數(shù)校驗Validator內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語言kube-scheduler深度剖析開發(fā)之scheduler初始化
這篇文章主要介紹了Go語言kube-scheduler深度剖析開發(fā)之scheduler初始化實現(xiàn)過程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04