Golang Gin 中间件 Next()方法示例详解

 更新时间:2023年04月10日 14:41:12   作者:富士康质检员张全蛋  
这篇文章主要介绍了Golang Gin 中间件 Next()方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

Next()方法

  • 在中间件中调用 next() 方法,会从 next() 方法调用的地方跳转到
  • Handler函数Handler函数执行完成,若中间件还有部分代码未执行(中间件中next()之后的代码),则执行该代码

如果第一个中间件处理直接使用了next函数,直接跳转到handler函数,处理完之后还会回过来处理剩下的中间件函数。

除了最中心的这块,其他的都是中间件,当我一个中间件进来,当我直接使用了next之后,直接跳到业务处理这部分的handler,然后业务处理的handler处理完毕之后,然后它再回跳到一层一层未处理完的这个中间件代码。

所以它就非常像洋葱,它其实中间件是一层一层,但是前面只执行了一半,处理完中间件之后是响应了,响应的时候还会再去处理剩下的这个中间件一层一层。

// 日志中间件
func MiddleWareLog() gin.HandlerFunc {
	//这里也是context,因为你的中间件也是对请求和响应的处理,只要涉及到请求和响应的处理就用到context上下文
	return func(c *gin.Context) {
		fmt.Println("log start")
		c.Next()
		fmt.Println("log end")
	}
}
 
func MiddleWareRequestId() gin.HandlerFunc {
	return func(c *gin.Context) {
		fmt.Println("request id start")
		c.Next()
		fmt.Println("request id end")
	}
}
func main() {
	r := gin.Default()
	r.Use(MiddleWareLog(), MiddleWareRequestId())
	r.GET("/", func(c *gin.Context) {
		fmt.Println("app handler.......")
		c.JSON(http.StatusOK, gin.H{
			"msg": "success",
		})
	})
	r.Run(":8000")
}

[GIN-debug] Listening and serving HTTP on :8000
log start
request id start
app handler.......
request id end
log end
[GIN] 2023/04/08 - 09:51:03 | 200 |      2.2505ms |             ::1 | GET      "/"

首先可以看到我先注册了log中间件,然后注册了requestid中间件的id。所以说是按照注册中间件的顺序来的,然后会执行完。

(1)如果上面中间件没有加入next函数,那么它会将中间件里面所有逻辑执行完

(2)如果只有一层中间件,那么在中间件中调用 next() 方法,会从 next() 方法调用的地方跳转到Handler函数。

如果有多层中间件,那么会跳转到链表里面下一个中间件,上面就是从log中间件跳转到request中间件了。在requestid中间件执行了next函数,它下面没有中间件了,只有业务代码了,那么就去执行业务的handler,并且执行好了之后我返回出去,最后执行剩下的中间件那部分没执行完的逻辑。

其实和洋葱一样,最开始执行的是最外面的一层,后执行的是最里面的一层。但是业务代码执行完了之后,我从最里面这层开始

业务场景:最里面这一层的中间件,就是requestid了,可以去做一个开始的计时,next()然后里面去执行业务代码,执行完之后返回里面再来一个结束的计时,那么就能够拿到这个方法的执行时间。

在写一些微服务框架,做一个metric的展现的时候,其实都是借助中间件这么做的,然后将数据暴露给一个接口,然后Prometheus去拿一下,最后展现出来,就是这样实现的。

实现token认证

http://127.0.0.1:8080/index index首页无需token直接访问

http://127.0.0.1:8080/home home家目录需要对token进行验证,验证通过才可访问

中间件最大的存储长度是60多,不能再往下存了。

c.abort()就是直接跳到链表最后一个, 后面没有了,那么也就执行完了,其他的中间件就不执行了。

package main
 
import (
	"fmt"
	"github.com/gin-gonic/gin"
	"net/http"
)
 
func AuthMiddleWare() gin.HandlerFunc {
	return func(c *gin.Context) {
		//常用场景,客户端也就是接口的调用方,客户端携带token的方式 1:请求头(最常用) 2:请求体 3:uri
		token := c.Request.Header.Get("token")
		fmt.Println("获取token信息:", token)
 
		if token != "qazw1234" {
			c.JSON(http.StatusOK, gin.H{
				"msg": "身份验证不通过",
			})
			//Abort方法用于跳到handler链表最后一个index,相当于直接退出,不执行后面的handler了
			c.Abort()
            return
		}
	}
}
 
func main() {
	r := gin.Default()
	r.GET("/home", AuthMiddleWare(), func(c *gin.Context) {
		c.JSON(http.StatusOK, gin.H{
			"msg": "home路由",
		})
	})
	r.Run(":8000")
}

到此这篇关于Golang Gin 中间件 Next()方法的文章就介绍到这了,更多相关Golang Gin 中间件 Next内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言中go mod vendor使用方法

    Go语言中go mod vendor使用方法

    go mod vendor的功能是将新增的依赖包自动写入当前项目的 vendor目录,下面这篇文章主要给大家介绍了关于Go语言中go mod vendor使用的相关资料,需要的朋友可以参考下
    2022-10-10
  • Golang中错误处理机制详解

    Golang中错误处理机制详解

    平时在项目开发过程中少不了对错误的处理,一个好用的系统首先要确保其健壮性,不能经常发生错误就卡死之类的情况,为了让我们的程序更加健壮,我们就需要知道golang里的错误处理机制是怎么样的,这篇文章带大家一起学习,需要的朋友跟着小编一起来看看吧
    2024-05-05
  • golang容易导致内存泄漏的6种情况汇总

    golang容易导致内存泄漏的6种情况汇总

    内存泄漏是我们在生产环境中必须面临的问题,下面这篇文章主要给大家介绍了关于golang容易导致内存泄漏的6种情况,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • 如何利用Golang解析读取Mysql备份文件

    如何利用Golang解析读取Mysql备份文件

    这篇文章主要给大家介绍了关于如何利用Golang解析读取Mysql备份文件的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Golang具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-12-12
  • go benchmark 基准测试详解

    go benchmark 基准测试详解

    这篇文章主要介绍了go benchmark 基准测试详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • Go语言工程实践单元测试基准测试示例详解

    Go语言工程实践单元测试基准测试示例详解

    这篇文章主要为大家介绍了Go语言工程实践单元测试基准测试示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • go语言map字典删除操作的方法

    go语言map字典删除操作的方法

    这篇文章主要介绍了go语言map字典删除操作的方法,实例分析了map字典操作的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • 简单四步快速集成go环境变量

    简单四步快速集成go环境变量

    这篇文章主要为大家介绍了快速集成go环境变量的简单四个步骤详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Go select 死锁的一个细节

    Go select 死锁的一个细节

    这篇文章主要给大家分享的是Go select 死锁的一个细节,文章先是对主题提出问题,然后展开内容,感兴趣的小伙伴可以借鉴一下,希望对你有所帮助
    2021-10-10
  • Go 语言中gin使用gzip压缩遇到的问题

    Go 语言中gin使用gzip压缩遇到的问题

    这篇文章主要介绍了Go 语言中gin使用gzip压缩遇到的问题,需要的朋友可以参考下
    2017-09-09

最新评论