GIN的路由以及傳參問題
1.路由:
func main() { r := gin.Default() r.GET("/ping/:name", func(c *gin.Context) { c.JSON(200, gin.H{ "message": c.Param("name"), }) fmt.Println(c.Param("name")) }) r.Run() // listen and serve on 0.0.0.0:8080 }
以冒號的形式設置url參數的話可以通過,對應的參數可以通過context.Param的形式獲得。但是存在問題 無法導向/ping本身
func main() { r := gin.Default() r.GET("/ping/*name", func(c *gin.Context) { c.JSON(200, gin.H{ "message": c.Param("name"), }) fmt.Println(c.Param("name")) }) r.Run() // listen and serve on 0.0.0.0:8080 }
這裡就存在另一種參數形式,也就是*,每次獲得的參數都將包含/,也可以作用於/ping,如果當前的路由中不存在/ping的處理形式,將會自動跳轉到/ping/並交給/ping/*name處理
並且/ping/*name與/ping/:name存在沖突,不能同時寫入路由。
2.傳參
func main() { r := gin.Default() r.GET("/ping", func(c *gin.Context) { c.JSON(200, gin.H{ ":message": c.Query("name"), }) }) r.Run() // listen and serve on 0.0.0.0:8080 }
當get傳參的時候(url上顯示的參數)
可以通過Context.Query來獲得對應的value,如果需要判斷是否為空,則可以使用Context.getQuery更加優雅,也可以使用Context.DefaultQuery類似於java中map的getOrDefault
當POST傳參的時候(請求寫入body)
可以通過Context.PostForm來獲得對應的value,如果需要判斷是否為空,則可以使用Context.getPostForm更加優雅,也可以使用Context.DefaultPostForm類似於java中map的getOrDefault。
但是測試的時候發現,似乎這個方法不像SpringMVC中的RequestBody可以獲取對應的JSON,這裡的操作會有些復雜,需要通過流,讀取Body,並且轉換成JSON,通過map讀取對應的參數
var user map[string]interface{} body, _ := ioutil.ReadAll(req.Body) json.Unmarshal(body, &user) fmt.Println("獲取json中的username:", user["username"]) fmt.Println("獲取json中的password:", user["password"].(string)) //轉字符串通過len(password)!=0判斷長度
以上時大致方法,這裡先提出一個疑問,看看後面的學習中是否能解決,不能直接通過中間件實現一個讀取轉化,從SpringMVC來看 這不是一個很難的輪子。
到此這篇關於GIN的路由以及傳參問題的文章就介紹到這瞭,更多相關GIN路由及傳參內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- golang微服務框架基礎Gin基本路由使用詳解
- golang gin框架獲取參數的操作
- gin 獲取post請求的json body操作
- Gin框架之參數綁定的實現
- 基於Go語言構建RESTful API服務