5.gin 中间件
5.1 全局中间件
package main
import (
"fmt"
"github.com/gin-gonic/gin"
"time"
)
func MiddleWare() gin.HandlerFunc {
return func(c *gin.Context) {
t := time.Now()
fmt.Println("中间件开始执行!")
c.Set("request", "中间件")
status := c.Writer.Status()
fmt.Println("中间件执行完毕",status)
t2 := time.Since(t)
fmt.Println("time", t2)
}
}
func main() {
r := gin.Default()
r.Use(MiddleWare())
{
r.GET("/ce", func(c *gin.Context) {
req, _ := c.Get("request")
fmt.Println("request:",req)
c.JSON(200, gin.H{"request":req})
})
r.Run()
}
}
中间件开始执行!
中间件执行完毕 200
time 20.312µs
request: 中间件
5.2 Next方法
- Next()函数,仅可以在中间件使用,它在调用函数中执行挂起的函数。
func MiddleWare() gin.HandlerFunc {
return func(c *gin.Context) {
t := time.Now()
fmt.Println("中间件开始执行!")
c.Set("request", "中间件")
c.Next()
status := c.Writer.Status()
fmt.Println("中间件执行完毕",status)
t2 := time.Since(t)
fmt.Println("time", t2)
}
}
func main() {
r := gin.Default()
r.Use(MiddleWare())
{
r.GET("/ce", func(c *gin.Context) {
req, _ := c.Get("request")
fmt.Println("request:",req)
c.JSON(200, gin.H{"request":req})
})
r.Run()
}
}
中间件开始执行!
request: 中间件
中间件执行完毕 200
time 37.267µs
5.3局部中间件
func main() {
r := gin.Default()
{
r.GET("/ce", MiddleWare(), func(c *gin.Context) {
req, _ := c.Get("request")
fmt.Println("request:",req)
c.JSON(200, gin.H{"request":req})
})
r.Run()
}
}
5.4中间件练习
package main
import (
"fmt"
"time"
"github.com/gin-gonic/gin"
)
func myTime(c *gin.Context) {
start := time.Now()
c.Next()
since := time.Since(start)
fmt.Println("程序用时:", since)
}
func main() {
r := gin.Default()
r.Use(myTime)
shoppingGroup := r.Group("/shopping")
{
shoppingGroup.GET("/index", shopIndexHandler)
shoppingGroup.GET("/home", shopHomeHandler)
}
r.Run(":8000")
}
func shopIndexHandler(c *gin.Context) {
time.Sleep(5 * time.Second)
}
func shopHomeHandler(c *gin.Context) {
time.Sleep(3 * time.Second)
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库