gin 模型绑定字段验证常用方法

7 篇文章 0 订阅

required 验证该值不是数据类型的默认零值。数字不为0,字符串不为 " ", slices, maps, pointers, interfaces, channels and functions 不为 nil

isdefault 验证该值为数据类型默认值


len=10 对于数字,长度将确保该值等于给定的参数。对于字符串,它会检查字符串长度是否与字符数完全相同。对于切片,数组和map,验证元素个数。

max=10 对于数字,max将确保该值小于或等于给定的参数。对于字符串,它会检查字符串长度是否最多为该字符数。对于切片,数组和map,验证元素个数。

eq=10 对于字符串和数字,eq将确保该值等于给定的参数。对于切片,数组和map,验证元素个数。
ne=10 和eq相反


oneof=red green (oneof=5 7 9) 对于字符串,整数和uint,oneof将确保该值是参数中的值之一。参数应该是由空格分隔的值列表。值可以是字符串或数字。

gt=10 对于数字,这将确保该值大于给定的参数。对于字符串,它会检查字符串长度是否大于该字符数。对于切片,数组和map,它会验证元素个数。

gt 对于time.Time确保时间值大于time.Now.UTC()

gte=10 大于等于

gte 对于time.Time确保时间值大于或等于time.Now.UTC()

lt=10 小于

lt 对于time.Time确保时间值小于time.Now.UTC()

lte=10 小于等于

lte 对于time.Time确保时间值小于等于time.Now.UTC()


unique 对于数组和切片,unique将确保没有重复项。对于map,unique将确保没有重复值。

alpha 这将验证字符串值是否仅包含ASCII字母字符

alphanum 这将验证字符串值是否仅包含ASCII字母数字字符

alphaunicode 这将验证字符串值是否仅包含unicode字符

alphanumunicode 这将验证字符串值是否仅包含unicode字母数字字符

numeric 这将验证字符串值是否包含基本数值。基本排除指数等…对于整数或浮点数,它返回true。

hexadecimal 这将验证字符串值是否包含有效的十六进制


hexcolor 这验证字符串值包含有效的十六进制颜色,包括#标签(#)

rgb 这将验证字符串值是否包含有效的rgb颜色

rgba 这将验证字符串值是否包含有效的rgba颜色

hsl 这将验证字符串值是否包含有效的hsl颜色

hsla 这将验证字符串值是否包含有效的hsla颜色


email 这验证字符串值包含有效的电子邮件这可能不符合任何rfc标准的所有可能性,但任何电子邮件提供商都不接受所有可能性

file 这将验证字符串值是否包含有效的文件路径,并且该文件存在于计算机上。这是使用os.Stat完成的,它是一个独立于平台的函数。

url 这会验证字符串值是否包含有效的url这将接受golang请求uri接受的任何url,但必须包含一个模式,例如http://或rtmp://

uri 这验证了字符串值包含有效的uri。这将接受uri接受的golang请求的任何uri

base64 这将验证字符串值是否包含有效的base64值。虽然空字符串是有效的base64,但这会将空字符串报告为错误,如果您希望接受空字符串作为有效字符,则可以将此字符串与omitempty标记一起使用。

base64url 这会根据RFC4648规范验证字符串值是否包含有效的base64 URL安全值。尽管空字符串是有效的base64 URL安全值,但这会将空字符串报告为错误,如果您希望接受空字符串作为有效字符,则可以将此字符串与omitempty标记一起使用。

btc_addr 这将验证字符串值是否包含有效的比特币地址。检查字符串的格式以确保它匹配P2PKH,P2SH三种格式之一并执行校验和验证

btc_addr_bech32 这验证了字符串值包含bip-0173定义的有效比特币Bech32地址(https://github.com/bitcoin/bips/blob/master/bip-0173.mediawiki)特别感谢Pieter Wuille提供的参考实现。

eth_addr 这将验证字符串值是否包含有效的以太坊地址。检查字符串的格式以确保它符合标准的以太坊地址格式完全验证被https://github.com/golang/crypto/pull/28阻止

contains=@ 这将验证字符串值是否包含子字符串值

containsany=!@#? 这将验证字符串值是否包含子字符串值中的任何Unicode code points。

containsrune=@ 这将验证字符串值是否包含提供的符文值。

excludes=@ 这验证字符串值不包含子字符串值。

excludesall=!@#? 这将验证字符串值在子字符串值中是否包含任何Unicode code points。

excludesrune=@ //这将验证字符串值是否包含提供的符文值。


ascii 这将验证字符串值是否仅包含ASCII字符。注意:如果字符串为空,则验证为true

printascii 这将验证字符串值是否仅包含可打印的ASCII字符。注意:如果字符串为空,则验证为true。

multibyte 这将验证字符串值是否包含一个或多个多字节字符。注意:如果字符串为空,则验证为true

datauri 这将验证字符串值是否包含有效的DataURI。注意:这也将验证数据部分是否有效base64

latitude 这将验证字符串值是否包含有效的纬度。

longitude 这将验证字符串值是否包含有效经度。

ssn 这将验证字符串值是否包含有效的美国社会安全号码。

ip 这将验证字符串值是否包含有效的IP地址

ipv4 这将验证字符串值是否包含有效的v4 IP地址

ipv6 这将验证字符串值是否包含有效的v6 IP地址

cidr 这将验证字符串值是否包含有效的CIDR地址

cidrv4 这将验证字符串值是否包含有效的v4 CIDR地址

cidrv5 这将验证字符串值是否包含有效的v5 CIDR地址

tcp_addr 这将验证字符串值是否包含有效的可解析TCP地址

tcp4_addr 这将验证字符串值是否包含有效的可解析v4 TCP地址

tcp6_addr 这将验证字符串值是否包含有效的可解析v6 TCP地址

udp_addr 这将验证字符串值是否包含有效的可解析UDP地址

udp4_addr 这将验证字符串值是否包含有效的可解析v4 UDP地址

udp6_addr 这将验证字符串值是否包含有效的可解析v6 UDP地址

ip_addr 这将验证字符串值是否包含有效的可解析IP地址

ip4_addr 这将验证字符串值是否包含有效的可解析v4 IP地址

ip6_addr 这将验证字符串值是否包含有效的可解析v6 IP地址

unix_addr 这将验证字符串值是否包含有效的Unix地址

mac //这将验证字符串值是否包含有效的MAC地址
//注意:有关可接受的格式和类型,请参阅Go的ParseMAC: http://golang.org/src/net/mac.go?s=866:918#L29

hostname //根据RFC 952 https://tools.ietf.org/html/rfc952验证字符串值是否为有效主机名

hostname_rfc1123 or if you want to continue to use ‘hostname’ in your tags, create an alias //根据RFC 1123 https://tools.ietf.org/html/rfc1123验证字符串值是否为有效主机名

fqdn //这将验证字符串值是否包含有效的FQDN (完全合格的有效域名),Full Qualified Domain Name (FQDN)

html //这将验证字符串值是否为HTML元素标记,包括https://developer.mozilla.org/en-US/docs/Web/HTML/Element中描述的标记。

html_encoded //这将验证字符串值是十进制或十六进制格式的正确字符引用

url_encoded //这验证了根据https://tools.ietf.org/html/rfc3986#section-2.1对字符串值进行了百分比编码(URL编码)

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gin框架中,参数绑定是将HTTP请求中的数据绑定到Go结构体中的过程。Gin框架支持多种参数绑定方式,包括将查询字符串参数绑定到结构体字段、将POST表单数据绑定到结构体字段、将JSON数据绑定到结构体字段等。 以下是一个示例,展示如何在Gin框架中使用参数绑定: ```go type User struct { Name string `form:"name"` Password string `form:"password"` } func main() { r := gin.Default() r.POST("/login", func(c *gin.Context) { var user User if err := c.ShouldBind(&user); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } // TODO: 验证用户名和密码 c.JSON(http.StatusOK, gin.H{"message": "登录成功"}) }) r.Run() // 启动服务 } ``` 在上面的示例中,我们定义了一个`User`结构体,并使用`form`标签指定了每个字段对应的查询字符串参数名。在处理`/login`路由时,我们使用`ShouldBind`方法将HTTP请求中的数据绑定到`User`结构体中,如果绑定失败,则返回一个错误响应。如果绑定成功,则可以使用`User`结构体中的字段进行用户名和密码验证,并返回成功响应。 需要注意的是,Gin框架使用了`ShouldBind`方法来实现参数绑定,这个方法会自动根据HTTP请求的Content-Type字段来选择绑定方式。如果Content-Type为application/json,则会将JSON数据绑定到结构体中;如果Content-Type为application/x-www-form-urlencoded,则会将POST表单数据绑定到结构体中,以此类推。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值