Go语言 Gin处理请求参数

1.获取Get 请求参数

获取Get请求参数的常用3个函数:

  • func (c *Context) Query(key string) string
  • func (c *Context) DefaultQuery(key, defaultValue string) string
  • func (c *Context) GetQuery(key string) (string, bool)

2.获取Post请求参数

获取Post请求参数的常用3个函数,与Get获取参数类似:

  • func (c *Context) PostForm(key string) string
  • func (c *Context) DefaultPostForm(key, defaultValue string) string
  • func (c *Context) GetPostForm(key string) (string, bool)

3.获取URL路径参数

获取URL路径参数,指的是获取 /user/:id 这类型路由绑定的参数,这个例子绑定了一个参数id。

获取url路径参数常用函数:

  • func (c *Context) Param(key string) string

4.将请求参数绑定到struct对象

前面获取参数的方式都是一个个参数的读取,实际应用中,Gin框架支持将请求参数自动绑定到一个struct对象,这种方式支持Get/Post请求,也支持http请求body内容为json/xml格式的参数。

示例

package main

import (
	"github.com/gin-gonic/gin"
	"net/http"
)

/*
gin 获取请求参数
*/
func main() {
	// 1.初始化实例
	r := gin.Default()

	// 2.路由。localhost:8080/get?name=xiao
	r.GET("/get", func(c *gin.Context) {
		// 直接通过Query获取
		name := c.Query("name")
		c.JSON(http.StatusOK, gin.H{
			"parms_name": name,
		})
	})
	// 1)正常取值:localhost:8080/title?title=xiao
	// 2) 无值,则取设置的默认值(default_title):localhost:8080/title
	r.GET("/title", func(c *gin.Context) {
		// 带默认值的参数获取
		title := c.DefaultQuery("title", "default_title")
		c.JSON(http.StatusOK, gin.H{
			"title": title,
		})
	})
	// 1)返回参数判断是否有值
	// 2) 参数不存在:localhost:8080/value
	// 3) 参数存在: localhost:8080/value?value=xiao
	r.GET("/value", func(c *gin.Context) {
		value, ok := c.GetQuery("value")
		if !ok {
			// 如果参数不存在
			c.JSON(http.StatusOK, gin.H{
				"message": "value not exist.",
			})
			return
		}
		c.JSON(http.StatusOK, gin.H{
			"value": value,
		})
	})
	// 1)post 默认,取参数值
	r.POST("/post", func(c *gin.Context) {
		// 直接获取post form参数值,为string类型
		name1 := c.PostForm("name")

		c.JSON(http.StatusOK, gin.H{
			"name1": name1,
		})
	})
	// 2)post 带默认值,取参数值
	r.POST("/defaultPost", func(c *gin.Context) {
		// 设置默认值,获取参数
		name2 := c.DefaultPostForm("name", "default_name")

		c.JSON(http.StatusOK, gin.H{
			"name2": name2,
		})
	})
	// 3)post 判断是否存在值,取参数值
	r.POST("/getPost", func(c *gin.Context) {
		// 判断参数是否在
		name3, ok := c.GetPostForm("name")
		if !ok {
			// 参数不存在
			c.JSON(http.StatusOK, gin.H{
				"message": "name param not exist.",
			})
			return
		}
		c.JSON(http.StatusOK, gin.H{
			"name3": name3,
		})
	})
	// 获取请求url中的值
	r.GET("/user/:id", func(c *gin.Context) {
		// 获取请求url中的参数id
		id := c.Param("id")
		c.JSON(http.StatusOK, gin.H{
			"id": id,
		})
	})
	// 绑定struct对象
	type User struct {
		Name string `json:"name" form:"name"`
		Age  int    `json:"age" form:"age"`
	}
	// 绑定参数:localhost:8080/user
	/*
		{
		    "name":"xi",
		    "age":18
		}
	*/
	r.POST("/user", func(c *gin.Context) {
		// 初始化对象
		u := User{}
		// 通过 ShouldBind 函数,将请求参数绑定到 struct 对象。
		if c.ShouldBind(&u) == nil {
			// 绑定成功,输出请求参数
			c.JSON(http.StatusOK, gin.H{
				"name": u.Name,
				"age":  u.Age,
			})
			return
		}
		c.JSON(http.StatusOK, gin.H{
			"message": "绑定失败",
		})
	})

	// 3.启动服务
	r.Run(":8080")
}