這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。
Golang已經是一個很豐富的語言了,包含很多的工具和庫。因為作者經常做Http開發工作,所以先來探索gin庫。
熟悉使用
第一步:安裝
$ go get github.com/gin-gonic/gin
第二步:引用
import "github.com/gin-gonic/gin"
第三步:代碼
func main() { // Disable Console Color // gin.DisableConsoleColor() // Creates a gin router with default middleware: // logger and recovery (crash-free) middleware router := gin.Default() router.GET("/someGet", getting) router.POST("/somePost", posting) router.PUT("/somePut", putting) router.DELETE("/someDelete", deleting) router.PATCH("/somePatch", patching) router.HEAD("/someHead", head) router.OPTIONS("/someOptions", options) // By default it serves on :8080 unless a // PORT environment variable was defined. router.Run() // router.Run(":3000") for a hard coded port}
使用說明
參數的利用
假設c *.gin.Context,那麼:
1、擷取路由參數是c.Param("name"),例如
r.GET("/user/:name", func(c *gin.Context) { name := c.Param("name") c.String(http.StatusOK, "Hello %s", name)})
2、擷取http的querystring,使用c.Query("name"),例如:
r.GET("/welcome", func(c *gin.Context) { firstname := c.DefaultQuery("firstname", "Guest") lastname := c.Query("lastname") // shortcut for c.Request.URL.Query().Get("lastname") c.String(http.StatusOK, "Hello %s %s", firstname, lastname)})
3、擷取post過來的參數,使用c.PostForm("name")
介面版本分組
1、版本是更新換代的一個保證
router := gin.Default() // Simple group: v1 v1 := router.Group("/v1") { v1.POST("/login", loginEndpoint) v1.POST("/submit", submitEndpoint) v1.POST("/read", readEndpoint) } // Simple group: v2 v2 := router.Group("/v2") { v2.POST("/login", loginEndpoint) v2.POST("/submit", submitEndpoint) v2.POST("/read", readEndpoint) }
中介軟體
無論前後端開發基本都涉及中介軟體middleware。不過路由基本也是一個middleware,作者把其他middleware都作為路由的一部分了。
r := gin.New()是不包含middleware的,而gin.Default是包含logger和recovery中介軟體的。
待續。。。