31

gin自动参数绑定工具

 4 years ago
source link: https://www.tuicool.com/articles/ZRvUjeN
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

golang gin 参数自动绑定工具

  • 基于 go-gin 的 json restful 风格的golang基础库
  • 自带请求参数过滤及绑定实现
  • 代码注册简单且支持多种注册方式

1、 目录结构说明

  • ginrpc/base/common.go 基础库
  • ginrpc/base/api/context.go 自定义context内容
  • 支持参数自动检测 binding:"required"validator
  • 支持rpc自动映射

2、api接口说明

支持3种接口模式

  • func(*gin.Context) //gogin 原始接口
  • func(*api.Context) //自定义的context类型
  • func(*api.Context,req) //自定义的context类型,带request 请求参数 func(*gin.Context,*req) ...... 等接口模式

示例代码

type ReqTest struct {
     Access_token string `json:"access_token"`                 //access_token
     UserName     string `json:"user_name" binding:"required"` //用户名
     Password     string `json:"password"`                     //新密码
 }

 //TestFun1 gin 默认的函数回调地址
 func TestFun1(c *gin.Context) {
 }

 //TestFun2 自定义context的函数回调地址
 func TestFun2(c *api.Context) {
 }

 //TestFun3 带自定义context跟已解析的req参数回调方式
 func TestFun3(c *api.Context, req *ReqTest) {
     fmt.Println(req)
 }

 //TestFun3 带自定义context跟已解析的req参数回调方式
 func TestFun4(c *gin.Context, req ReqTest) {
     fmt.Println(req)
 }

 func main() {
     router := gin.Default()
     router.POST("/test1", base.GetHandlerFunc(TestFun1))
     router.POST("/test2", base.GetHandlerFunc(TestFun2))
     router.POST("/test3", base.GetHandlerFunc(TestFun3))
     router.POST("/test4", base.GetHandlerFunc(TestFun4))

     router.Run(":8080")
 }
  • curl
    curl 'http://127.0.0.1:8080/test4' -H 'Content-Type: application/json' -d '{"access_token":"111", "user_name":"222", "password":"333"}'

传送门

如果你喜欢,请'star'


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK