php小編魚仔為大家帶來一款實用的開發工具-Go Gin框架中的通用自訂驗證器。作為一款高效能的Web框架,Go Gin提供了強大的驗證器功能,幫助開發者在處理使用者輸入時保證資料的合法性和完整性。通用自訂驗證器可根據開發需求自訂各種驗證規則,簡化程式碼編寫流程,提高開發效率。本文將為大家詳細介紹如何建立通用自訂驗證器,並說明其使用方法和注意事項。無論您是初學者還是有開發經驗的開發者,都能從中受益匪淺。讓我們一起來探索Go Gin框架中的通用自訂驗證器吧!
我正在使用 go gin 在我的專案中建立 api。我需要建立自訂驗證器,因此我創建瞭如下內容:
var valueone validator.func = func(fl validator.fieldlevel) bool { value, ok := fl.field() if ok { if value != "one" { return true } } return true } var valuetwo validator.func = func(fl validator.fieldlevel) bool { value, ok := fl.field() if ok { if value != "two" { return true } } return true } ....
有沒有辦法建立一個更通用且可用於兩種情況的單一驗證器,而不是多次建立幾乎相同的自訂驗證器,例如:
var value validator.Func = func(fl validator.FieldLevel, param) bool { value, ok := fl.Field() if ok { if value != param { return true } } return true }
我無法找到一種方法將參數傳遞給杜松子酒中的自訂驗證器或透過任何其他可能的方式來製作這些通用驗證器。我需要創建數千個幾乎相似的驗證器,但我不想為每個驗證器建立自訂驗證器。
您無法變更函數結構,因為這是它在套件中定義的方式。
// func accepts a fieldlevel interface for all validation needs. the return // value should be true when validation succeeds. type func func(fl fieldlevel) bool
相反,我們可以嘗試使用參數自訂驗證標記
請參閱下面的範例
package main import ( "github.com/go-playground/validator" ) type Data struct { One string `json:"one" validate:"custom_validation=one"` Two string `json:"two" validate:"custom_validation=two"` } var validate *validator.Validate func main() { validate = validator.New() err := validate.RegisterValidation("custom_validation", func(fl validator.FieldLevel) bool { value := fl.Field() param := fl.Param() return value.String() == param }) if err != nil { panic(err) } // this will succeed { data := &Data{ One: "one", Two: "two", } err = validate.Struct(data) if err != nil { panic(err) } } // it will fail here { data := &Data{ Two: "one", One: "two", } err = validate.Struct(data) if err != nil { panic(err) } } }
在此處查看更多範例
注意:golang不支援! ==
以上是Go Gin:建立通用自訂驗證器的詳細內容。更多資訊請關注PHP中文網其他相關文章!