查詢與 POST 表單
處理 POST 請求時,你經常需要同時從 URL 查詢字串和請求主體讀取值。Gin 將這兩個來源分開,讓你可以獨立存取每個來源:
c.Query("key")/c.DefaultQuery("key", "default")—— 從 URL 查詢字串讀取。c.PostForm("key")/c.DefaultPostForm("key", "default")—— 從application/x-www-form-urlencoded或multipart/form-data請求主體讀取。
這在 REST API 中很常見,路由透過查詢參數(如 id)識別資源,而主體則攜帶有效負載(如 name 和 message)。
package main
import ( "fmt" "net/http"
"github.com/gin-gonic/gin")
func main() { router := gin.Default()
router.POST("/post", func(c *gin.Context) { id := c.Query("id") page := c.DefaultQuery("page", "0") name := c.PostForm("name") message := c.PostForm("message")
fmt.Printf("id: %s; page: %s; name: %s; message: %s\n", id, page, name, message) c.String(http.StatusOK, "id: %s; page: %s; name: %s; message: %s", id, page, name, message) })
router.Run(":8080")}測試
# Query params in URL, form data in bodycurl -X POST "http://localhost:8080/post?id=1234&page=1" \ -d "name=manu&message=this_is_great"# Output: id: 1234; page: 1; name: manu; message: this_is_great
# Missing page -- falls back to default value "0"curl -X POST "http://localhost:8080/post?id=1234" \ -d "name=manu&message=hello"# Output: id: 1234; page: 0; name: manu; message: hello