教程 > gin 教程 > 阅读:89

gin 中间件——迹忆客-ag捕鱼王app官网

gin框架允许开发者在处理请求的过程中,加入钩子函数,这个钩子函数就叫中间件。中间件适合处理一些公共的业务逻辑,比如登陆认证,权限校验,记录日志等。具体使用方法如下

package main
import (
    "fmt"
    "net/http"
    "time"
    "github.com/gin-gonic/gin"
)
//定义一个中间键m1统计请求处理函数耗时
func m1(c *gin.context) {
    fmt.println("m1 in...")
    start := time.now()
    // c.next() //调用后续的处理函数
    c.abort()//阻止调用后续的处理函数
    cost := time.since(start)
    fmt.printf("cost:%v\n", cost)
}
func index(c *gin.context) {
    c.json(http.statusok, gin.h{
        "msg": "ok",
    })
}
func main() {
    r := gin.default()
    r.get("/", m1, index)
    r.run()
}

在中间件中使用goroutine

当在中间件或 handler 中启动新的 goroutine 时,不能使用原始的上下文,必须使用只读副本。

package main
import (
    "github.com/gin-gonic/gin"
    "log"
    "time"
)
func main() {
    r := gin.default()
    r.get("/long_async", func(c *gin.context) {
        // 创建在 goroutine 中使用的副本
        tmp := c.copy()
        go func() {
            // 用 time.sleep() 模拟一个长任务。
            time.sleep(5 * time.second)
            // 请注意您使用的是复制的上下文 "tmp",这一点很重要
            log.println("done! in path "   tmp.request.url.path)
        }()
    })
    r.get("/long_sync", func(c *gin.context) {
        // 用 time.sleep() 模拟一个长任务。
        time.sleep(5 * time.second)
        // 因为没有使用 goroutine,不需要拷贝上下文
        log.println("done! in path "   c.request.url.path)
    })
    r.run()
}

查看笔记

扫码一下
查看教程更方便
网站地图