golang web框架 Gin 详解(二)|Go主题月

360 阅读3分钟

golang web框架 Gin 详解(二)|Go主题月

回顾

上一期,我们讲述了一个简单的web应用的搭建和访问。这一期我们的主要内容是

  • gin中间件的使用
  • post和get请求的参数获取方式
  • ...

中间件

使用场景:

  • auth权限认证
  • 跨域
  • 其他需要在业务处理之前处理的事务

我们接着上一期的工程继续

查看一下目录

go-gin-test tree -L 3 
.
├── go.mod
├── go.sum
├── hello
├── mian.go
└── routerex
    └── router.go

routerex目录下新建mid目录 在mid目录下新建mid.go文件

首先我们定义一个中间件。它的作用是在请求到达服务后,但是还未进行业务处理时,需要验证请求是否合法

编辑mid.go

package mid

import (
	"github.com/gin-gonic/gin"
)

func midAuth(c *gin.Context) {
	//获取请求的ip地址
	ip := c.ClientIP()
	//如果请求地址来源不正确,那么阻止这个请求继续
	if ip != "baidu.com" {
		println("ip 地址不正确")
                c.Abort()
		return
	}
	// 处理请求
	c.Next()
}

编辑router.go

package routerex

import (
	"example.com/m/v2/routerex/mid"
	"github.com/gin-gonic/gin"
)

func InitRouter(g *gin.Engine) {
	g1 := g.Group("g1")
	//中间件
	g1.Use(mid.MidAuth)
	g1.GET("/hello1", func(c *gin.Context) {
		c.JSON(200, gin.H{
			"msg": "Hello g1",
		})
	})

	g2 := g.Group("g2")
	g2.GET("/hello2", func(c *gin.Context) {
		c.JSON(200, gin.H{
			"msg": "Hello g2",
		})
	})

}

执行go build -o hello来编译为可执行文件

go-gin-test go build -o hello
➜  go-gin-test ls
go.mod   go.sum   hello    mian.go

执行./hello让我们的服务跑起来

打开浏览器访问http://localhost:8080/g1/hello1

image.png

[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.

[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- using env:   export GIN_MODE=release
- using code:  gin.SetMode(gin.ReleaseMode)

[GIN-debug] GET    /g1/hello1                --> example.com/m/v2/routerex.InitRouter.func1 (4 handlers)
[GIN-debug] GET    /g2/hello2                --> example.com/m/v2/routerex.InitRouter.func2 (3 handlers)
[GIN-debug] Environment variable PORT is undefined. Using port :8080 by default
[GIN-debug] Listening and serving HTTP on :8080
ip 地址不正确
[GIN] 2021/04/06 - 17:00:38 | 200 |      61.658µs |             ::1 | GET      "/g1/hello1"

可以看到我们的浏览器上没有任何输出

但是在后台日志上,我们看到了我们在代码中打印的ip 地址不正确

通过这个思路,我们可以实现很多业务或者场景的需求。

下面这个代码就是通用的跨域中间件

func midCors(c *gin.Context) {
  c.Header("Access-Control-Allow-Origin", c.Request.Header.Get("Origin"))
  c.Header("Access-Control-Allow-Headers", "*")
  c.Header("Access-Control-Allow-Methods", "*")
  c.Header("Access-Control-Allow-Credentials", "true")

  //放行所有OPTIONS方法
  if c.Request.Method == "OPTIONS" {
  	c.AbortWithStatus(http.StatusNoContent)
  }
  // 处理请求
  c.Next()
}

POST和GET获取值的方式

  • Parameters in path (url路径参数)
name := c.Param("name")
  • Querystring parameters
//这个写法具有默认值
firstname := c.DefaultQuery("firstname", "Guest")
  • Multipart/Urlencoded Form(表单)
//无默认值
message := c.PostForm("message")
//有默认值
nick := c.DefaultPostForm("nick", "anonymous")
  • Map as querystring or postform parameters(Map或者表单)
ids := c.QueryMap("ids")
names := c.PostFormMap("names")
  • file(文件类型)
form, _ := c.MultipartForm()
files := form.File["upload[]"]
  • JSON
//结构体
j := J{}
c.BindJSON(j)

当然除了上述常用的方式之外,gin还提供的更加丰富的获取参数的方式。

大家可以通过上面的demo来尝试一下。

下一期的内容预告

  • 如何使用gin构建一个标准的web工程
  • 如何使用gin写出标准的api接口
  • ...

想获取工程的同学可以关注超级英雄吉姆,在公众号里发送gin,获取工程。

如果你有更多的想知道的内容或者有什么好的建议,可以在评论里回复,或者关注我的公众号超级英雄吉姆,在公众号留言,我看到后第一时间回复。