成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Gin 框架怎么使用自定義驗證器?

開發 前端
本文我們介紹 Gin 框架怎么使用自定義驗證器,分別列舉了字段級別和結構體級別自定義驗證器的使用方式。需要注意的是,它們并不是線程安全的,需要在任何驗證之前,先注冊自定義驗證器。

1.介紹

Gin 框架自定義驗證器,分為字段級別驗證器和結構體級別驗證器。

其中結構體級別驗證器,可以用于跨字段驗證,也可以用于和字段級別驗證器結合使用。

需要注意的是,結構體級別驗證器的優先級小于字段級別驗證器。

2.字段級別自定義驗證器

定義字段級別驗證器

示例代碼:

var userValidator validator.Func = func(fl validator.FieldLevel) bool {
 val, ok := fl.Field().Interface().(string)
 if ok {
  illegalName := []string{"admin", "Admin", "guest", "Guest"}
  for _, v := range illegalName {
   if v == val {
    return false
   }
  }
 }
 return true
}

閱讀上面這段代碼,我們定義一個 validator.Func 類型的函數變量,參數入參的類型是 validator.FieldLevel,返回結果是一個 bool 類型的變量。

函數體中,使用類型斷言,獲取字段的值,然后進行邏輯驗證。

注冊自定義驗證器

示例代碼:

func main() {
 r := gin.Default()
 // 注冊自定義驗證器
 if v, ok := binding.Validator.Engine().(*validator.Validate); ok {
  err := v.RegisterValidation("user_validator", userValidator)
  if err != nil {
   return
  }
 }
 r.GET("/login", Login)
 err := r.Run()
 if err != nil {
  return
 }
}

閱讀上面這段代碼,我們使用 RegisterValidation 方法,注冊自定義驗證器 userValidator,該方法接收的第一個參數是用于結構體字段的 tag 名稱,第二個參數是自定義驗證器的函數名稱。

需要注意的是,如果我們注冊的驗證器標簽名(用于結構體字段的 tag 名稱)已存在,則會被當前驗證器函數替換掉。

使用自定義驗證器

示例代碼:

func Login(c *gin.Context) {
 user := &User{}
 err := c.ShouldBind(user)
 if err != nil {
  c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
  return
 }
 c.JSON(http.StatusOK, gin.H{
  "data": user,
 })
}

type User struct {
 Name     string `form:"name" binding:"required,user_validator"`
 Password string `form:"password"`
}

閱讀上面這段代碼,我們在請求參數結構體的字段中,添加我們注冊自定義驗證器時的標簽名 user_validator,即可使用自定義驗證器。

輸出結果:

curl -s -X GET http://127.0.0.1:8080/login\?name\=admin\&password\=123456 | jq
{
  "error": "Key: 'User.Name' Error:Field validation for 'Name' failed on the 'user_validator' tag"
}

3.結構體級別自定義驗證器

定義結構體級別驗證器

示例代碼:

func UserStructLevelValidation(sl validator.StructLevel) {
 user := sl.Current().Interface().(User)
 if len(user.TrueName) == 0 && len(user.NickName) == 0 {
  sl.ReportError(user.TrueName, "TrueName", "true_name", "true_name_or_nick_name", "")
  sl.ReportError(user.TrueName, "NickName", "nick_name", "true_name_or_nick_name", "")
 }
}

閱讀上面這段代碼,我們定義一個函數,該函數接收一個 validator.StructLevel 類型的參數,函數體中使用類型斷言,獲取結構體的值,然后進行邏輯驗證。

注冊自定義驗證器

示例代碼:

func main() {
 r := gin.Default()
 // 注冊自定義驗證器
 if v, ok := binding.Validator.Engine().(*validator.Validate); ok {
  v.RegisterStructValidation(UserStructLevelValidation, User{})
 }
 r.POST("/register", Register)
 err := r.Run()
 if err != nil {
  return
 }
}

閱讀上面這段代碼,我們使用 RegisterStructValidation 方法,注冊自定義驗證器 UserStructLevelValidation,該方法接收兩個參數,分別是 StructLevelFunc 函數類型的自定義驗證器,和需要驗證的結構體類型。

使用自定義驗證器

示例代碼:

func Register(c *gin.Context) {
 var user User
 err := c.ShouldBind(&user)
 if err != nil {
  c.JSON(http.StatusBadRequest, gin.H{
   "error": err.Error(),
  })
  return
 }
 c.JSON(http.StatusOK, gin.H{
  "data": user,
 })
}

type User struct {
 TrueName string `json:"true_name"`
 NickName string `json:"nick_name"`
 Password string `json:"password" binding:"required"`
}

閱讀上面這段代碼,我們不需要在結構體字段標簽中有任何操作,即可使用自定義結構體級別的驗證器。

以下是結構體級別驗證器單獨使用,和結合字段級別驗證器(標簽驗證器)一起使用的輸出結果。

輸出結果:

curl -s -H "content-type: application/json" -X POST -d '{"true_name": "", "nick_name": "", "password": "123456"}' http://127.0.0.1:8080/register | jq
{
  "error": "Key: 'User.TrueName' Error:Field validation for 'TrueName' failed on the 'true_name_or_nick_name' tag\nKey: 'User.NickName' Error:Field validation for 'NickName' failed on the 'true_name_or_nick_name' tag"
}

curl -s -H "content-type: application/json" -X POST -d '{"true_name": "", "nick_name": "", "password": ""}' http://127.0.0.1:8080/register | jq  
{
  "error": "Key: 'User.Password' Error:Field validation for 'Password' failed on the 'required' tag\nKey: 'User.TrueName' Error:Field validation for 'TrueName' failed on the 'true_name_or_nick_name' tag\nKey: 'User.NickName' Error:Field validation for 'NickName' failed on the 'true_name_or_nick_name' tag"
}

4.總結

本文我們介紹 Gin 框架怎么使用自定義驗證器,分別列舉了字段級別和結構體級別自定義驗證器的使用方式。

需要注意的是,它們并不是線程安全的,需要在任何驗證之前,先注冊自定義驗證器。

責任編輯:武曉燕 來源: Golang語言開發棧
相關推薦

2025-03-31 01:30:00

Gin框架模型

2024-12-09 00:00:15

Gin框架中間件

2024-11-11 00:45:54

Gin框架字段

2023-10-24 13:48:50

自定義注解舉值驗證

2009-02-10 12:55:39

自定義控件AJAX.NET

2009-06-25 14:53:35

自定義UI組件JSF框架

2019-12-25 11:47:27

LinuxFVWM

2022-01-14 09:17:13

PythonAPISIX插件

2009-06-23 11:35:44

JSF的Naviati

2010-10-25 16:05:07

oracle自定義函數

2022-05-07 10:22:32

JavaScript自定義前端

2009-07-07 14:32:47

JDK日志Formatter

2009-11-24 15:11:21

ASP.NET MVC

2024-02-19 07:40:10

2021-01-14 19:04:36

框架數據庫mybatis

2022-09-13 15:44:52

VSLook插件

2021-10-28 08:39:22

Node Export自定義 監控

2015-02-12 15:33:43

微信SDK

2025-02-08 11:49:42

2009-07-07 14:00:25

JDK日志Handler
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 最新av中文字幕 | 欧美精品一区三区 | 成人免费毛片片v | 中文字幕不卡在线88 | 国产亚洲精品91 | 国产精品国产亚洲精品看不卡15 | 久草青青草 | 日韩精品免费一区二区在线观看 | 日本中文在线 | 一级免费毛片 | 精品中文视频 | 亚洲免费婷婷 | 精品一区二区电影 | 网址黄| 在线免费看黄 | 香蕉视频黄色 | 特级黄一级播放 | a视频在线观看 | 91n成人| 久热m3u8| 久久综合香蕉 | 国产精品99免费视频 | 天天综合网天天综合色 | 日韩免费毛片视频 | 一区二区不卡视频 | 黑人巨大精品 | 欧美网站一区二区 | 性国产丰满麻豆videosex | 91久久精品一区二区二区 | 亚洲久久在线 | a在线视频| 国产综合网站 | 欧美日韩一区二区在线播放 | 粉嫩av| 国产精品久久久久久久一区二区 | 啪啪免费| 久久国产亚洲 | 黄色网址在线播放 | 超碰在线免费av | 国产欧美一区二区三区另类精品 | 久久久久国产一区二区三区四区 |