新手问题 gin自动参数绑定工具,rpc支持

xie1xiao1jun · 2019年06月22日 · 92 次阅读

golang gin 参数自动绑定工具

  • ginrpc
  • 基于 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) ...... 等接口模式

示例代码

  package main

import (
    "fmt"
    "net/http"

    "github.com/gin-gonic/gin"
    "github.com/xxjwxc/ginrpc/base"
    "github.com/xxjwxc/ginrpc/base/api"
)

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) {
    fmt.Println(c.Params)
    c.String(200, "ok")
}

//TestFun2 自定义context的函数回调地址
func TestFun2(c *api.Context) {
    fmt.Println(c.Params)
    c.JSON(http.StatusOK, "ok")
}

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

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

    c.JSON(http.StatusOK, 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'

更多原创文章干货分享,请关注公众号
  • 加微信实战群请加微信(注明:实战群):gocnio
暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册