前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Go Web框架gin的入门教程

Go Web框架gin的入门教程

作者头像
会呼吸的Coder
发布2020-02-17 16:51:34
1.3K0
发布2020-02-17 16:51:34
举报
文章被收录于专栏:会呼吸的Coder会呼吸的Coder

目前,基于Go的web框架也可谓是百花齐放了,之所以选择gin ,没其他原因,就只是因为其在github上的star数是最多的,而且仅仅从README看,其文件也是相当丰富的。

安装gin

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

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

代码语言:javascript
复制
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
}

路由

代码语言:javascript
复制
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")
})
 

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

请求与响应

代码语言:javascript
复制
// 获取路由参数,假设路由为"/user/:name"
c.Params.ByName("name")
 
// 获取query的数据
c.Query("name")
c.DefaultQuery("name", "Guest")
 
// 获取表单参数
c.PostForm("name")
c.DefaultPostForm("name")

请求验证

响应

代码语言:javascript
复制
// 返回简单的字符串
c.String(200, "pong")
 
// 返回JSON数据
c.JSON(200, gin.H{
  "message": "pong",
})
 
// 重定向
c.Redirect(http.StatusMovedPermanently, "https://breathcoder.com")

中间件

自定义中中间件

BasicAuth中间件

非同步协程

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

代码语言:javascript
复制
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)
  }()
}
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-11-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 初级程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装gin
  • 路由
  • 请求与响应
  • 请求验证
  • 中间件
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档