扫码一下
查看教程更方便
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()
}
当在中间件或 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()
}