Golang Go语言中 JSON 的验证 后端的 json 验证
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
打错了,是一直都 nil
更多关于Golang Go语言中 JSON 的验证 后端的 json 验证的实战系列教程也可以访问 https://www.itying.com/category-94-b0.html
除非你传递的不是合格的 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
时,你需要:
- 定义结构体并添加验证标签。
- 使用
validator.Validate
函数对解析后的结构体进行验证。 - 处理验证错误。
这种方法不仅提高了代码的可读性和维护性,还大大简化了JSON数据验证的复杂性。
总之,在Golang中进行JSON验证时,根据具体需求选择合适的工具和方法是关键。无论是标准库还是第三方库,都能帮助你确保数据的准确性和安全性。