go gin Next()方法

示例

gin Next()使用方法

复制代码
package main

import (
	"fmt"
	"github.com/gin-gonic/gin"
	"net/http"
)

func main() {

	r := gin.Default()
	m1 := func(c *gin.Context) {
		fmt.Println("m1 start")
		//c.Next()会跳过当前中间件后续的逻辑,类似defer,最后再执行c.Next后面的逻辑
		//多个c.Next()谁在前面谁后执行,跟defer很像,类似先进后出的栈
		c.Next()
		fmt.Println("m1 end")
	}
	m2 := func(c *gin.Context) {
		fmt.Println("m2 start")
		//该方法会阻止业务逻辑以及该中间件后面中间件执行,但是不会阻止该中间件后面的逻辑执行包括c.Next()
		//c.Abort()
		c.Next()
		fmt.Println("m2 end")
	}
	m3 := func(c *gin.Context) {
		fmt.Println("m3 start")
		c.Next()
		fmt.Println("m3 end")
	}
	r.Use(m1, m2, m3)
	r.GET("/", func(context *gin.Context) {
		context.Next()
		context.JSON(http.StatusOK, gin.H{
			"message": "demo",
		})
		fmt.Println("hello world!!")
	})

	r.Run(":8081")
}

命令行输出

复制代码
[GIN-debug] Listening and serving HTTP on :8081
m1 start
m2 start
m3 start
hello world!!
m3 end
m2 end
m1 end
[GIN] 2021/03/26 - 12:40:40 |?[97;42m 200 ?[0m|      1.5781ms |       127.0.0.1 |?[97;44m GET     ?[0m "/"
posted @   牛奔  阅读(510)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示