18、Go Gin框架中的binding验证器使用

一、binding功能介绍

Gin的binding包提供了一组功能,用于将请求的数据自动绑定到结构体,并根据结构体标签进行数据验证。常用的标签有bindingvalidate,通过这些标签可以指定数据的类型和验证规则。

常见标签

  • binding:"required":表示该字段为必填项

  • binding:"-":忽略该字段,不进行绑定

  • validate:"max=10":表示该字段的值不能超过10

  • validate:"min=1":表示该字段的值不能小于1

  • validate:"email":表示该字段必须是合法的邮箱格式

结构体定义示例

type User struct {
	Name  string `json:"name" binding:"required" validate:"min=3,max=20"`
	Email string `json:"email" binding:"required" validate:"email"`
	Age   int    `json:"age" binding:"required" validate:"min=1,max=100"`
}

在上述示例中,我们定义了一个User结构体,并为每个字段添加了binding和validate标签,指定了各字段的绑定和验证规则。

二、Gin中使用binding和验证器

图片

1. 安装Gin和validator

首先,我们需要安装Gin框架和validator库,可以使用以下命令进行安装:

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

go-playground/validator是一个用于 Go 语言的结构体和字段验证包。它具有以下特点:

  • 支持跨字段和跨结构体验证

  • 支持自定义验证器

  • 提供丰富的验证约束

  • 易于使用

以下是该包的一些常见用途:

  • 验证 API 请求参数

  • 验证表单数据

  • 验证数据库模型

2. 绑定数据并验证

在Gin中,我们可以通过ShouldBindShouldBindJSON方法将请求的数据绑定到结构体,并进行验证。下面是一个具体的示例:

package main

import (
	"github.com/gin-gonic/gin"
	"github.com/go-playground/validator/v10"
	"net/http"
)

// User 结构体
type User struct {
	Name  string `json:"name" binding:"required" validate:"min=3,max=20"`
	Email string `json:"email" binding:"required" validate:"email"`
	Age   int    `json:"age" binding:"required" validate:"min=1,max=100"`
}

// CustomValidator 自定义验证器
type CustomValidator struct {
	validate *validator.Validate
}

// ValidateStruct 验证结构体
func (cv *CustomValidator) ValidateStruct(obj interface{}) error {
	if err := cv.validate.Struct(obj); err != nil {
		return err
	}
	return nil
}

// Main 函数
func main() {
	r := gin.Default()
	//中间件实现验证器验证
	r.Use(func(c *gin.Context) {
		cv := &CustomValidator{validate: validator.New()}
		c.Set("validator", cv)
	})

	//{"name":"shiph","email":"123@qq.com","age":31}
	r.POST("/user", func(c *gin.Context) {
		var user User
		if err := c.ShouldBind(&user); err != nil { //绑定
			c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
			return
		}

		if v, ok := c.MustGet("validator").(*CustomValidator); ok { //校验
			if err := v.ValidateStruct(&user); err != nil {
				c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
				return
			}
		}
		c.JSON(http.StatusOK, gin.H{"message": "用户创建成功!", "user": user})
	})

	r.Run()
}

3. 自定义验证器

有时,内置的验证器无法满足我们的需求,我们可以定义自己的验证器。例如,我们希望验证用户名不能包含特殊字符,可以通过自定义验证器实现:

package main

import (
	"fmt"
	"github.com/gin-gonic/gin"
	"github.com/go-playground/validator/v10"
	"net/http"
	"strings"
	"unicode"
)

// User 结构体
type User struct {
	Name  string `json:"name" binding:"required" validate:"min=3,max=20"`
	Email string `json:"email" binding:"required" validate:"email"`
	Age   int    `json:"age" binding:"required" validate:"min=1,max=100"`
}

func isValidUsername(fl validator.FieldLevel) bool {
	username := fl.Field().String()
	for _, char := range username {
		if !unicode.IsLetter(char) && !unicode.IsDigit(char) {
			return false
		}
	}
	return true
}


func main() {
	r := gin.Default()
	validate := validator.New()
	//通过validate.RegisterValidation方法注册了一个自定义验证器isValidUsername,用于验证用户名是否包含特殊字符
	validate.RegisterValidation("username", isValidUsername)

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

		if err := validate.Struct(user); err != nil {
			c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
			return
		}

		c.JSON(http.StatusOK, gin.H{"message": "创建用户成功!", "user": user})
	})

	r.Run()
}

在上述示例中,我们通过validate.RegisterValidation方法注册了一个自定义验证器isValidUsername,用于验证用户名是否包含特殊字符。

四、错误处理

在实际开发中,数据验证错误需要及时反馈给客户端。Gin的binding验证器会在数据验证失败时返回详细的错误信息,我们可以根据这些错误信息进行处理:

func handleError(err error) string {
	if errs, ok := err.(validator.ValidationErrors); ok {
		var errMsgs []string
		for _, e := range errs {
			errMsgs = append(errMsgs, fmt.Sprintf("Field: %s, Error: %s", e.Field(), e.Tag()))
		}
		return strings.Join(errMsgs, ", ")
	}
	return err.Error()
}

通过上述handleError函数,我们可以将验证错误格式化为易于阅读的错误信息。

五、总结

Gin框架中的binding验证器为我们提供了简便的数据绑定和验证功能,通过合理使用binding和validate标签,我们可以确保API接口的数据合法性和完整性。此外,结合自定义验证器和错误处理机制,可以进一步提高数据验证的灵活性和用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/677840.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

今日好料推荐(运维服务管理流程+互联网运维)

今日好料推荐(运维服务管理流程互联网运维) 本文内容是运维服务管理的梳理 参考资料内容:运维服务管理流程设计&互联网运维理论与实践 参考资料在文末获取,关注我,分享优质前沿资料(IT、运维、编码、…

斜拉桥智慧施工数字孪生

基于图扑自主研发的 HT for Web 产品,利用现场照片及 CAD 图纸,结合 PBR 材质,搭建了具有赛博朋克风格的智慧斜拉桥可视化解决方案,精准复现斜拉桥建造规划过程,辅助运维人员对桥梁基建过程的网格化管理。提高桥梁的建…

【Spring Cloud Alibaba】Nacos统一配置管理

目录 回顾问题 统一配置管理配置中心的解决方案:Nacos的关键特性动态配置服务小结 Nacos的架构 Spring Cloud Alibaba Nacos Config1.创建项目2.添加依赖3.添加启动注解4.添加配置信息5.使用控制器类动态读取配置信息6.Nacos Server添加配置信息7.测试 Nacos Namesp…

大疆、西圣、枫笛领夹麦哪个好?大疆、西圣领夹麦克风测评对比

不知道大家有没有想过一个问题,为什么有些视频或直播的声音听起来那么清晰,仿佛身临其境?其实最主要的就是麦克风的原因,我们以前用的麦克风或多或少都会存在一些小毛病例如:音质不清晰、传输不稳定容易断断续续、声音…

国内PLM系统厂商,国内PLM系统哪个公司最受欢迎

国内PLM系统厂商,国内PLM系统哪个公司最受欢迎 国内PLM系统厂商中,要确定哪个公司的产品最受欢迎,需要考虑多个因素,包括市场份额、客户评价、技术实力、产品线完整性以及服务支持等。虽然无法直接给出一个具体的“最受欢迎”的排名&#xff…

centos7安装kubernetes v1.28.2

centos7安装kubernetes v1.28.2 一.环境部署 1.1基础环境配置 主机IP 主机名规划 172.17.48.15 master 172.17.48.3 node1 1.2修改机器名称 #永久修改主机名 hostnamectl set-hostname master && bash #在master上操作 hostnamectl set-hostname …

分层存储的图片的3d显示

分层存储的图片叠层成为3d,并显示。 文件夹D:\mask内的分层存储的图像文件: 1、显示为3d点云: import open3d as o3d import numpy as np from PIL import Imagedef convert_images_to_point_cloud(image_paths):points []for i, image_pa…

windows中安装zookeeper

https://zhuanlan.zhihu.com/p/692451839 【zookeeper】在Windows上启动zookeeper_windows启动zk-CSDN博客 Index of /apache/zookeeper/zookeeper-3.9.2 Index of /apache/zookeeper/zookeeper-3.9.2 Zookeeper的应用场景 1、配置管理 2、服务注册中心 3、主从协调 4、…

【OpenHarmony】ArkTS 语法基础 ③ ( @Component 自定义组件生命周期回调函数 | @Entry 页面生命周期回调函数 )

文章目录 一、ArkTS Component 自定义组件生命周期1、自定义组件生命周期2、aboutToAppear 函数执行时机和作用3、aboutToDisappear 函数执行时机和作用4、代码示例 二、ArkTS Entry 页面生命周期1、Entry 页面生命周期2、onBackPress 和 onPageHide 回调函数无关联 三、代码示…

【NoSQL数据库】Redis简介

Redis Redis简介 Redis关系型数据库和非关系型数据库Redis 简介redis速度快的原因 Redis 配置Linux 源码安装 关系型数据库和非关系型数据库 关系型数据库(Relational Database)和非关系型数据库(Non-Relational Database)是两种…

[个人感悟] 多线程问题应该考察哪些问题? (Java篇)

前言 “如何做一个合格的多线程开发者? 你真的懂多线程么?” 作为编程初学者被问的最多的问题, 本文就这个问题. 详细的讲讲对方究竟为什么要问这个问题, 并且回答问题的主要思路框架. PS: 本文主体背景为Java语言. 其他语言应当为同理. 问题 - 单线程问题 什么是…

中信建投证券信息技术部PMO高级经理张子洋受邀为第十三届中国PMO大会演讲嘉宾

全国PMO专业人士年度盛会 中信建投证券股份有限公司信息技术部PMO高级经理张子洋先生受邀为PMO评论主办的2024第十三届中国PMO大会演讲嘉宾,演讲议题为“浅谈项目管理标准化的建设及实践分享”。大会将于6月29-30日在北京举办,敬请关注! 议题…

[Flask]开源项目--基于Faster R-CNN的在线害虫识别系统

项目演示效果可见视频: 【现已开源】害虫在线识别系统-基于pytorchflaskhttps://www.bilibili.com/video/BV1yx4y1u74y/?vd_source80963105a0c8d89bb119f3ebca249b22!!!---本项目仅供交流学习,禁止商用---&#xff0…

【外汇天眼】选择外汇EA的关键:策略适配、风险控制与稳定性评估

外汇EA(Expert Advisor)是外汇交易市场中广泛使用的自动化交易系统。它们通过预定义的规则和算法自动执行交易,旨在为交易者提供便捷的交易体验,同时提高交易效率和准确性。本文将从策略选择、风险控制和稳定性评估三个方面&#…

1panel服务器面板迁移Docker容器存储路径

1panel服务器面板迁移Docker容器存储路径 1、停止Docker服务 找到容器菜单,在配置中点击停止。 2、迁移Docker容器目录 Docker默认存储目录/var/lib/docker 2.1、无已部署容器 删除docker目录,避免额外的磁盘空间占用。 2.2、有已部署容器 若需保留…

AIGC绘画设计基础——迄今为止你还没学会用AI提高工作效率吗?

对于我来说,在工作效率提升,绘画创意生成,视频制作等等方面,都有了质的飞跃提高。 下面我分别从不同方面说一下AI带给我的提效,并且也分享我用的好用工具给到大家。 一、工作提效 我的本职工作是从事设计管理工作&am…

YOLOv5改进 | 注意力机制 | 添加SimAM注意力机制【全网独家+附完整代码】

💡💡💡本专栏所有程序均经过测试,可成功执行💡💡💡 压缩和激励模块(SE)以及空间通道注意力模块(CBAM)的注意力机制取得了巨大成功。本文介绍了一…

功能强大且专业的PDF转换软件PDF Shaper Professional 14.2

PDF Shaper Professional是一款适用于Windows的程序,可让您在计算机上处理PDF文件。 要开始使用PDF Shaper Professional,您需要在Windows计算机上下载并安装该程序。您还应该有合适的驱动程序和编解码器来处理计算机上的文本和图形。 安装程序后&#…

从零开始入门 LangChain

前言 最近一直在做 RAG 相关的内容,也学习了一段时间 LangChain 框架的用法。 本篇文章中将和大家讲述什么是 LangChain ,以及 LangChain 解决了现在大模型发展的哪些问题,然后会讲解LangChain 中基础的概念和组件。在此基础上,…

经纬恒润成功研发LRR610雷达先进算法!

好消息!经纬恒润搭载Arbe芯片组的LRR610 4D成像雷达算法开发出先进的后点云算法,并已圆满完成集成工作,这标志着智能驾驶感知系统迈向了一个新的里程碑。 经纬恒润自主开发的成像雷达算法,可以有效地跟踪数百个运动和静止目标&am…