Golang Go语言中 JSON 的验证 后端的 json 验证

发布于 1周前 作者 eggper 来自 Go语言

Golang Go语言中 JSON 的验证 后端的 json 验证

后端用 gin 写个自用的接口,假设结构体为下面

type Machine struct {
    Hostname string `json:"Hostname,omitempty" binding:"required"`
    DeviceLabel string `json:"DeviceLabel,omitempty" binding:"required"`
}

POST 接口必要的字段都写了 required 了,但是更新的时候发来的 json 的不一定会是全面的(也就不能用 gin 的 c.BindJson ),所以目前是下面写的

	var data models.Machines
if err := json.NewDecoder(c.Request.Body).Decode(&data); err != nil {
	c.JSON( http.StatusOK, gin.H{
		"status": 1,
		"msg":    err.Error(),
	})
	return
}

但是这样我测试了下任何正确的 json 都不会为 nil,例如:

{"asdasd":"asdasfdsf"}

搜了下 beego 的 validation 包也不能达到要求,如何让用户只能传递符合结构体的 json


更多关于Golang Go语言中 JSON 的验证 后端的 json 验证的实战系列教程也可以访问 https://www.itying.com/category-94-b0.html

13 回复

打错了,是一直都 nil

更多关于Golang Go语言中 JSON 的验证 后端的 json 验证的实战系列教程也可以访问 https://www.itying.com/category-94-b0.html


是 err 一直都 nil

除非你传递的不是合格的 json 数据才会有错误的

那我感觉这函数都没啥卵用,或者平时的开发中,后端接口都不去检查 json 的 key 是否随便写吗

我感觉你都没看懂问题。。。

这样在 Go 里是不行的,你必须调用 gin 的 json-check 方法去检查 json 是否合法,因为 binding 是 gin 库里的,你调的 json 是标准库里的

网上随便找了一篇你可以参考一下 https://www.yoytang.com/go-gin-doc.html 跳转到 数据验证 部分

https://godoc.org/github.com/gin-gonic/gin#Context.ShouldBind

ShouldBindXXX 不会直接发送错误响应,返回错误还能继续其他逻辑

为啥不去 A 站文章区???

不是,是 json 本身合法,但是 key 随便写,我现在给 model 的结构体加了个 IsEmpty 的方法整的,这样凑合着用吧

数据验证是验证你 binding:“required” 这部分,不是验证 json 本身合法性的,是验证结构合法性的

在Golang中,JSON验证是确保数据完整性和安全性的重要步骤,特别是在处理来自外部源的JSON数据时。Go语言提供了一些强大的工具和库来简化这一过程,最常用的包括标准库中的encoding/json以及第三方库如go-playground/validator

使用标准库encoding/json进行基础验证

Go的标准库encoding/json能够解析JSON数据并映射到结构体中,但基本的验证(如类型检查)需要开发者在代码中显式处理。例如,通过定义结构体并使用json.Unmarshal解析数据,然后手动检查每个字段是否符合预期。

使用第三方库go-playground/validator进行高级验证

对于更复杂的验证需求,如字段间的约束、正则表达式匹配等,go-playground/validator库是一个很好的选择。它提供了丰富的标签(如required, min, max, email等)来定义验证规则,并且可以轻松集成到Go项目中。

使用go-playground/validator时,你需要:

  1. 定义结构体并添加验证标签。
  2. 使用validator.Validate函数对解析后的结构体进行验证。
  3. 处理验证错误。

这种方法不仅提高了代码的可读性和维护性,还大大简化了JSON数据验证的复杂性。

总之,在Golang中进行JSON验证时,根据具体需求选择合适的工具和方法是关键。无论是标准库还是第三方库,都能帮助你确保数据的准确性和安全性。

回到顶部