go gin中間件關于 c.next()、c.abort()和return的使用小結
c.netx()
測試代碼
package main
import (
"fmt"
"github.com/gin-gonic/gin"
"log"
"net/http"
)
func main() {
g := gin.New()
g.Use(middleware1(), middleware2())
g.GET("/", func(c *gin.Context) {
fmt.Println("process request")
c.JSON(http.StatusOK, "hello,world!")
})
err := g.Run()
if err != nil {
log.Fatal(err)
}
}
func middleware1() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware1 start")
c.Next()
fmt.Println("middleware1 end")
}
}
func middleware2() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware2 start")
c.Next()
fmt.Println("middleware2 end")
}
}訪問 http://127.0.0.1:8080 執(zhí)行結果如下,瀏覽器輸出 “hello,world!”
middleware1 start
middleware2 start
process request
middleware2 end
middleware1 end
總結
中間件的執(zhí)行順序是按照注冊的順序執(zhí)行的,在中間件中使用 c.Next() 方法,會先執(zhí)行c.Next() 前面的,然后將控制權傳遞給下一個中間件或處理器,最后按照相反順序執(zhí)行中間件c.Next() 后面的代碼。 c.abort() 測試代碼
package main
import (
"fmt"
"github.com/gin-gonic/gin"
"log"
"net/http"
)
func main() {
g := gin.New()
g.Use(middleware1(), middleware2(), middleware3())
g.GET("/", func(c *gin.Context) {
fmt.Println("process request")
c.JSON(http.StatusOK, "hello,world!")
})
err := g.Run()
if err != nil {
log.Fatal(err)
}
}
func middleware1() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware1 start")
c.Next()
fmt.Println("middleware1 end")
}
}
func middleware2() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware2 start")
c.Abort()
fmt.Println("middleware2 end")
}
}
func middleware3() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware3 start")
c.Next()
fmt.Println("middleware3 end")
}
}訪問 http://127.0.0.1:8080 執(zhí)行結果如下,瀏覽器無輸出
middleware1 start
middleware2 start
middleware2 end
middleware1 end
總結
中間件的執(zhí)行順序是按照注冊順序執(zhí)行的,中間件可以通過 c.Abort() 來中止后續(xù)中間件或處理器的處理流程。
return 測試代碼
package main
import (
"fmt"
"github.com/gin-gonic/gin"
"log"
"net/http"
)
func main() {
g := gin.New()
g.Use(middleware1(), middleware2(), middleware3())
g.GET("/", func(c *gin.Context) {
fmt.Println("process request")
c.JSON(http.StatusOK, "hello,world!")
})
err := g.Run()
if err != nil {
log.Fatal(err)
}
}
func middleware1() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware1 start")
c.Next()
fmt.Println("middleware1 end")
}
}
func middleware2() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware2 start")
return
fmt.Println("middleware2 end")
}
}
func middleware3() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware3 start")
c.Next()
fmt.Println("middleware3 end")
}
}訪問 http://127.0.0.1:8080 執(zhí)行結果如下,瀏覽器輸出 “hello,world!”
middleware1 start
middleware2 start
middleware3 start
process request
middleware3 end
middleware1 end
總結
中間件的執(zhí)行順序是按照注冊順序執(zhí)行的,中間件可以通過 retrurn 來中止當前中間件的后續(xù)處理流程。
c.abort() +return 測試代碼
package main
import (
"fmt"
"github.com/gin-gonic/gin"
"log"
"net/http"
)
func main() {
g := gin.New()
g.Use(middleware1(), middleware2(), middleware3())
g.GET("/", func(c *gin.Context) {
fmt.Println("process request")
c.JSON(http.StatusOK, "hello,world!")
})
err := g.Run()
if err != nil {
log.Fatal(err)
}
}
func middleware1() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware1 start")
c.Next()
fmt.Println("middleware1 end")
}
}
func middleware2() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware2 start")
c.Abort()
return
fmt.Println("middleware2 end")
}
}
func middleware3() gin.HandlerFunc {
return func(c *gin.Context) {
fmt.Println("middleware3 start")
c.Next()
fmt.Println("middleware3 end")
}
}訪問 http://127.0.0.1:8080 執(zhí)行結果如下,瀏覽器無輸出
middleware1 start
middleware2 start
middleware1 end
總結
中間件的執(zhí)行順序是按照注冊順序執(zhí)行的,中間件可以通過 c.abort() + retrurn 來中止當前中間件,后續(xù)中間件和處理器的處理流程。
到此這篇關于go gin中間件關于 c.next()、c.abort()和return的使用的文章就介紹到這了,更多相關go gin中間件c.next()、c.abort()和return內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Go|使用Options模式和建造者模式創(chuàng)建對象實戰(zhàn)
這篇文章主要介紹了Go使用Options模式和建造者模式創(chuàng)建對象實戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
golang定時器Timer的用法和實現(xiàn)原理解析
這篇文章主要介紹了golang定時器Ticker,本文主要來看一下Timer的用法和實現(xiàn)原理,需要的朋友可以參考以下內(nèi)容2023-04-04

