Gin使用方法

安装gin

直接使用 go get github.com/gin-gonic/gin 即可。

官方README中提供了非常多的例子。例如最简单的实例代码:

package main
import "github.com/gin-gonic/gin"
func main() {
 r := gin.Default()
 r.GET("/ping", func(c *gin.Context) {
 c.JSON(200, gin.H{
  "message": "pong",
 })
 })
 r.Run() // listen and serve on 0.0.0.0:8080
}

路由

router := gin.Default() // 默认是带有Logger和Recovery中间件的
router := gin.New() // 不带中间件的路由
router.Use(gin.Logger()) // 可以使用这种方式来指明中间件
router.GET("/test", MyMiddleware(), testEndpoint) // 也可以用这种方式给指定路由添加中间件
router.GET("/someGet", getting) // 支持所有Restful的操作
// 带参数的路由
router.GET("/user/:name", func(c *gin.Context) {
 name := c.Param("name")
})

// 参数可选/通配符功能
router.GET("/user/:name/*action", ...)

// 路由分组
v1 := router.Group("/v1")
{
  v1.POST("/login", loginEndpoint)
  v1.POST("/submit", submitEndpoint)
}
v1.Use(AuthRequired()) {} // 路由分组单独指定中间件

请求与响应

请求

// 获取路由参数,假设有路由为"/user/:name"
c.Params.ByName("name")

// 获取query参数
c.Query("name")
c.DefaultQuery("name", "Guest")

// 获取表单参数
c.PostForm("name")
c.DefaultPostForm("name")

参数绑定

请求验证

响应

// 返回简单的字符串
c.String(200, "pong")

// 返回JSON数据
c.JSON(200, gin.H{
  "message": "pong",
})

// 重定向
c.Redirect(http.StatusMovedPermanently, "https://google.com")

中间件

自定义中间件

BasicAuth中间件

异步协程

gin可以借助协程来实现异步任务,但是这时候得手动copy上下文,并且只能是可读取的。

router.GET("/async", func(c *gin.Context) {
  cCp := c.Copy()
  go func() {
    time.Sleep(5 * time.Second)
    log.Println("Done! in path" + cCp.Request.URL.Path)
  }()
})

   转载规则


《Gin使用方法》 MarkHoo 采用 知识共享署名 4.0 国际许可协议 进行许可。
 上一篇
Go官网资源 Go官网资源
Go语言中文官网镜像及资源Go中国官网笨鸟学GO Go 语言之旅Go 编程语言Go语言文档翻译(QQ群:368836416) Download GoMicrosoft Windows: go1.11.1.windows-amd64.msi
2018-10-30
下一篇 
Go关键字和预定义标识符 Go关键字和预定义标识符
Go 语言中的关键字(25个) 关键字 描述 break 退出循环 default 选择结构默认项(switch、select) func 定义函数 interface 定义接口 select channel
2018-10-14
  目录