目前,基于Go的web框架也可謂是百花齊放了,之所以選擇 gin ,沒其他原因,就只是因為其在github上的star數(shù)是最多的,而且僅僅從README看,其文檔也是相當(dāng)豐富的。
安裝gin
直接使用 go get github.com/gin-gonic/gin 即可。
官方README中提供了非常多的例子。例如最簡單的實例代碼:
package main import "github.com/gin-gonic/gin" func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ "message": "pong", }) }) r.Run() // listen and serve on 0.0.0.0:8080 }
路由
router := gin.Default() // 默認(rèn)是帶有Logger和Recovery中間件的 router := gin.New() // 不帶中間件的路由 router.Use(gin.Logger()) // 可以使用這種方式來指明中間件 router.GET("/test", MyMiddleware(), testEndpoint) // 也可以用這種方式給指定路由添加中間件 router.GET("/someGet", getting) // 支持所有Restful的操作 // 帶參數(shù)的路由 router.GET("/user/:name", func(c *gin.Context) { name := c.Param("name") }) // 參數(shù)可選/通配符功能 router.GET("/user/:name/*action", ...) // 路由分組 v1 := router.Group("/v1") { v1.POST("/login", loginEndpoint) v1.POST("/submit", submitEndpoint) } v1.Use(AuthRequired()) {} // 路由分組單獨(dú)指定中間件
請求與響應(yīng)
請求
// 獲取路由參數(shù),假設(shè)有路由為"/user/:name" c.Params.ByName("name") // 獲取query參數(shù) c.Query("name") c.DefaultQuery("name", "Guest") // 獲取表單參數(shù) c.PostForm("name") c.DefaultPostForm("name")
參數(shù)綁定
請求驗證
響應(yīng)
// 返回簡單的字符串 c.String(200, "pong") // 返回JSON數(shù)據(jù) c.JSON(200, gin.H{ "message": "pong", }) // 重定向 c.Redirect(http.StatusMovedPermanently, "https://google.com")
中間件
自定義中間件
BasicAuth中間件
異步協(xié)程
gin可以借助協(xié)程來實現(xiàn)異步任務(wù),但是這時候得手動copy上下文,并且只能是可讀取的。
router.GET("/async", func(c *gin.Context) { cCp := c.Copy() go func() { time.Sleep(5 * time.Second) log.Println("Done! in path" + cCp.Request.URL.Path) }() })
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
標(biāo)簽:滄州 瀘州 泰安 駐馬店 東營 昭通 阿壩 晉中
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Go Web框架gin的入門教程》,本文關(guān)鍵詞 Web,框架,gin,的,入門教程,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。