码迷,mamicode.com
首页 > 其他好文 > 详细

go gin Next()方法

时间:2021-03-26 15:28:25      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:context   使用方法   业务逻辑   end   message   ack   lis   text   list   

示例

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 "/"

go gin Next()方法

标签:context   使用方法   业务逻辑   end   message   ack   lis   text   list   

原文地址:https://www.cnblogs.com/niuben/p/14581733.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!