Go的gin參數校驗中的validator庫詳解
更新時間:2023年08月18日 14:18:33 作者:Looooking
這篇文章主要介紹了Go的gin參數校驗之validator庫,使用 validator 以后,只需要在定義結構體時使用 binding 或 validate tag標識相關校驗規(guī)則,就可以進行參數校驗了,而不用自己單獨去寫常見的校驗規(guī)則,需要的朋友可以參考下
使用 validator 以后,只需要在定義結構體時使用 binding 或 validate tag標識相關校驗規(guī)則,就可以進行參數校驗了,而不用自己單獨去寫常見的校驗規(guī)則。
main.go
package main
import (
"fmt"
"github.com/go-playground/validator/v10"
"github.com/go-playground/locales/zh_Hans_CN"
unTrans "github.com/go-playground/universal-translator"
zhTrans "github.com/go-playground/validator/v10/translations/zh"
)
type User struct {
Username string `validate:"min=6,max=10,contains=ook,startswith=He"`
Age uint8 `validate:"gte=1,lte=10"`
Sex string `validate:"oneof=female male"`
Email string `validate:"email"`
}
func main() {
validate := validator.New()
//user := User{Username: "Heooking", Age: 6, Sex: "male", Email: "test@qq.com"}
user := User{Username: "Looking", Age: 26, Sex: "male", Email: "qq.com"}
err := validate.Struct(user)
// 默認英文提示
if err != nil {
fmt.Println(err)
//Key: 'User.Username' Error:Field validation for 'Username' failed on the 'startswith' tag
//Key: 'User.Age' Error:Field validation for 'Age' failed on the 'lte' tag
//Key: 'User.Email' Error:Field validation for 'Email' failed on the 'email' tag
}
fmt.Println()
// 中文錯誤提示
uni := unTrans.New(zh_Hans_CN.New())
trans, _ := uni.GetTranslator("zh_Hans_CN")
zhTrans.RegisterDefaultTranslations(validate, trans)
if err != nil {
for _, v := range err.(validator.ValidationErrors) {
fmt.Println(v.Translate(trans))
//Username必須以文本'He'開頭
//Age必須小于或等于10
//Email必須是一個有效的郵箱
}
}
}go.mod
module test go 1.17 require ( github.com/go-playground/validator/v10 v10.15.0 ) require ( github.com/gabriel-vasile/mimetype v1.4.2 // indirect github.com/go-playground/locales v0.14.1 // indirect github.com/go-playground/universal-translator v0.18.1 // indirect github.com/leodido/go-urn v1.2.4 // indirect golang.org/x/crypto v0.7.0 // indirect golang.org/x/net v0.8.0 // indirect golang.org/x/sys v0.6.0 // indirect )
常用約束如下:
字符串約束
- excludesall:不包含參數中任意的 UNICODE 字符,例如excludesall=ab;
- excludesrune:不包含參數表示的 rune 字符,excludesrune=asong;
- startswith:以參數子串為前綴,例如startswith=hi;
- endswith:以參數子串為后綴,例如endswith=bye。
- contains=:包含參數子串,例如contains=email;
- containsany:包含參數中任意的 UNICODE 字符,例如containsany=ab;
- containsrune:包含參數表示的 rune 字符,例如`containsrune=asong;
- excludes:不包含參數子串,例如excludes=email;
范圍約束
范圍約束的字段類型分為三種:
- 對于數值,我們則可以約束其值
- 對于切片、數組和map,我們則可以約束其長度
- 對于字符串,我們則可以約束其長度
常用 tag 介紹:
- ne:不等于參數值,例如 ne=5;
- gt:大于參數值,例如 gt=5;
- gte:大于等于參數值,例如 gte=50;
- lt:小于參數值,例如 lt=50;
- lte:小于等于參數值,例如 lte=50;
- oneof:只能是列舉出的值其中一個,這些值必須是數值或字符串,以空格分隔,如果字符串中有空格,將字符串用單引號包圍,例如 oneof=male female。
- eq:等于參數值,注意與 len不同。對于字符串, eq約束字符串本身的值,而 len約束字符串長度。例如 eq=10;
- len:等于參數值,例如 len=10;
- max:小于等于參數值,例如 max=10;
- min:大于等于參數值,例如 min=10
- Fields約束
- eqfield:定義字段間的相等約束,用于約束同一結構體中的字段。例如: eqfield=Password
- eqcsfield:約束統(tǒng)一結構體中字段等于另一個字段(相對),確認密碼時可以使用,例如: eqfiel=ConfirmPassword
- nefield:用來約束兩個字段是否相同,確認兩種顏色是否一致時可以使用,例如: nefield=Color1
- necsfield:約束兩個字段是否相同(相對)
常用約束
- unique:指定唯一性約束,不同類型處理不同:
對于map,unique約束沒有重復的值
對于數組和切片,unique沒有重復的值
對于元素類型為結構體的碎片,unique約束結構體對象的某個字段不重復,使用 unique=field指定字段名
- email:使用email來限制字段必須是郵件形式,直接寫eamil即可,無需加任何指定。
- omitempty:字段未設置,則忽略
- -:跳過該字段,不檢驗;
- |:使用多個約束,只需要滿足其中一個,例如rgb|rgba;
- required:字段必須設置,不能為默認值;
到此這篇關于Go的gin參數校驗之validator庫的文章就介紹到這了,更多相關Go validator庫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Go處理json數據方法詳解(Marshal,UnMarshal)
這篇文章主要介紹了Go處理json數據的方法詳解,Marshal(),UnMarshal(),需要的朋友可以參考下2022-04-04

