当前位置: 首页 > news >正文

Go 语言结构体验证详解:validate 标签与自定义规则

介绍

        Go 语言中,结构体验证是保障数据完整性和正确性的重要手段之一。本文将深入探讨 validate 标签的使用方式,并介绍如何结合验证库 go-playground/validator 进行自定义验证规则。

安装与导入验证库

首先,请确保已安装验证库:

go get -u github.com/go-playground/validator/v10

在代码中导入验证库:

import "github.com/go-playground/validator/v10"

基本用法

使用 validate 标签为结构体字段定义基本验证规则:

type User struct {Username string `validate:"required,min=3,max=20"`Email    string `validate:"required,email"`Age      int    `validate:"gte=18"`
}

在上述示例中:

  • required 表示字段值不能为空。
  • min=3max=20 表示字符串长度必须在 3 到 20 之间。
  • email 要求字段值是有效的电子邮件地址。
  • gte=18 表示数字字段必须大于等于 18。

自定义验证规则

为了满足特定业务需求,我们可以定义自己的验证规则。首先,创建一个自定义验证函数:

func customRule(fl validator.FieldLevel) bool {// 自定义验证逻辑,返回 true 表示验证通过,false 表示验证失败value := fl.Field().String()return value == "custom_value"
}

然后,在结构体字段的 validate 标签中引用这个函数:

type MyStruct struct {CustomField string `validate:"customRule"`
}

嵌套结构体验证

验证库支持嵌套结构体的验证。例如,如果有一个嵌套的 Address 结构体:

type User struct {Username string  `validate:"required"`Email    string  `validate:"required,email"`Address  Address `validate:"required"`
}type Address struct {Street string `validate:"required"`City   string `validate:"required"`
}

在这个例子中,Address 结构体的验证规则会被嵌套到 User 结构体的验证中。

切片和数组的元素验证

对于切片和数组,我们可以使用 dive 标签进行元素级别的验证:

type MyStruct struct {Numbers []int `validate:"required,dive,gte=0,lte=100"`
}

这表示 Numbers 切片中的每个元素必须在 0 到 100 之间。

自定义错误消息

我们可以为每个验证规则定义自定义的错误消息:

type User struct {Username string `validate:"required,min=3,max=20" error:"用户名不能为空,长度必须在3到20之间"`
}

在这个例子中,如果验证失败,将使用自定义的错误消息而不是默认的错误消息。

使用验证器进行验证

创建验证器实例,使用其 Struct 方法进行结构体验证:

func main() {validate := validator.New()user := User{Username: "john_doe",Email:    "john@example.com",Address: Address{Street: "123 Main St",City:   "Anytown",},}if err := validate.Struct(user); err != nil {// 处理验证错误for _, err := range err.(validator.ValidationErrors) {fmt.Println(err.Field(), err.Tag(), err.Param(), err.ActualTag(), err.Namespace())}return}fmt.Println("Validation passed!")
}

在验证失败时,我们可以获取每个字段的详细错误信息,进行进一步的处理。

结论

        通过 validate 标签与验证库的结合,我们可以方便地定义和执行验证规则,确保数据的完整性和正确性。自定义验证规则、嵌套结构体验证、切片和数组元素验证等功能为开发者提供了更多灵活性,让结构体验证更加强大。

http://www.lryc.cn/news/234532.html

相关文章:

  • ​软考-高级-系统架构设计师教程(清华第2版)【第19章 大数据架构设计理论与实践 (P691~716)-思维导图】​
  • 深度学习YOLOv5车辆颜色识别检测 - python opencv 计算机竞赛
  • c语言-浅谈指针(3)
  • 从服务器端获取人脸数据,在本地检测特征,并将特征发送给服务器
  • ARDUINO UNO 12颗LED超酷流水灯效果
  • Linux下查看pytorch运行时真正调用的cuda版本
  • ​分享mfc140u.dll丢失的解决方法,针对原因解决mfc140u.dll丢失的问题
  • torch_cluster、torch_scatter、torch_sparse三个包的安装
  • 软件安利——火绒安全
  • Induced AI:一个专门为自动化任务而设计的AI原生浏览器RPA平台
  • vue3中使用reactive定义的变量响应式丢失问题(大坑!!!)
  • Windows Server 2012 R2系统服务器远程桌面服务多用户登录配置分享
  • mysql之搭建MHA架构实现高可用
  • Databend 与海外某电信签约:共创海外电信数据仓库新纪元
  • scala解析命令行参数
  • 盘点60个Python各行各业管理系统源码Python爱好者不容错过
  • SpringSecurity6 | 自动配置(下)
  • 6、传统CV之均值滤波
  • 快速搭建本地的chatgpt
  • 分布式下多节点WebSocket消息收发
  • LeetCode算法题解(动态规划)|LeetCode509. 斐波那契数、LeetCode70. 爬楼梯、LeetCode746. 使用最小花费爬楼梯
  • 【图像处理】:Otsu算法最大类间方差法(大津算法:附源码)
  • 【uni-app】设置背景颜色相关
  • 工厂模式-C++实现
  • 安装应用与免安装应用差异对比
  • FiscoBcos使用Go调用合约
  • 自然语言处理(NLP)-spacy简介以及安装指南(语言库zh_core_web_sm)
  • CTF-PWN-tips
  • 《Effective C++》条款21
  • 决策树,sql考题,30个经典sql题目