[TOC]
## 獲取Get請求參數
> 例子:/path?id=1234&name=Manu&sex=male
> 獲取Get請求參數的常用函數:
> `func (c *Context) Query(key string) string`
> `func (c *Context) DefaultQuery(key, defaultValue string) string`
> `func (c *Context) GetQuery(key string) (string, bool)`
~~~
func DoHandler(c *gin.Context) {
//獲取name參數, 通過Query獲取的參數值是String類型。
name := c.Query("name")
//獲取name參數, 跟Query函數的區別是,可以通過第二個參數設置默認值。
name := c.DefaultQuery("name", "golang")
//獲取id參數, 通過GetQuery獲取的參數值也是String類型,
// 區別是GetQuery返回兩個參數,第一個是參數值,第二個參數是參數是否存在的bool值,可以用來判斷參數是否存在。
id, ok := c.GetQuery("id")
if !ok {
// 參數不存在
}
}
~~~
> 提示:GetQuery函數,判斷參數是否存在的邏輯是,參數值為空,參數也算存在,只有沒有提交參數,才算參數不存在。
## 獲取Post請求參數
> 獲取Post請求參數的常用函數:
> `func (c *Context) PostForm(key string) string`
> `func (c *Context) DefaultPostForm(key, defaultValue string) string`
> `func (c *Context) GetPostForm(key string) (string, bool)`
~~~
func DoHandler(c *gin.Context) {
//獲取name參數, 通過PostForm獲取的參數值是String類型。
name := c.PostForm("name")
// 跟PostForm的區別是可以通過第二個參數設置參數默認值
name := c.DefaultPostForm("name", "golang")
//獲取id參數, 通過GetPostForm獲取的參數值也是String類型,
// 區別是GetPostForm返回兩個參數,第一個是參數值,第二個參數是參數是否存在的bool值,可以用來判斷參數是否存在。
id, ok := c.GetPostForm("id")
if !ok {
// 參數不存在
}
}
~~~
## 獲取URL路徑參數
> 例子:/user/:id/:name
> 獲取url路徑參數常用函數:
> `func (c *Context) Param(key string) string`
~~~
r := gin.Default()
r.GET("/user/:id/:name", func(c *gin.Context) {
// 獲取url的綁定參數
id := c.Param("id")
name := c.Param("name")
})
~~~
## 將請求參數綁定到struct對象
> 前面獲取參數都是一個個的讀取方式,比較麻煩,Gin框架支持將請求參數自動綁定到一個struct對象,這種方式支持Get/Post請求,也支持http請求body內容為json/xml格式的參數。
**User struct對象:**
~~~
// User 結構體定義
type User struct {
Name string `json:"name" form:"name"`
Email string `json:"email" form:"email"`
}
~~~
**struct標簽說明:**
| 標簽 | 說明 |
| --- | --- |
| json:"name" | 數據格式為json格式,并且json字段名為name |
| form:"name" | 表單參數名為name |
> 提示:你可以根據自己的需要選擇支持的數據類型,例如需要支持json數據格式,可以這樣定義字段標簽: json:"name"
**控制器代碼:**
~~~
r.GET("/user", func(c *gin.Context) {
// 初始化user struct
u := User{}
// 通過ShouldBind函數,將請求參數綁定到struct對象, 處理json請求代碼是一樣的。
// 如果是post請求則根據Content-Type判斷,接收的是json數據,還是普通的http請求參數
if c.ShouldBind(&u) == nil {
// 綁定成功, 打印請求參數
log.Println(u.Name)
log.Println(u.Email)
}
// http 請求返回一個字符串
c.String(200, "Success")
})
~~~
## Gin如何獲取客戶ip
~~~
r.GET("/ip", func(c *gin.Context) {
// 獲取用戶IP
ip := c.ClientIP()
})
~~~
- 基礎知識
- 開發環境
- 包名規則
- 包初始化 (init)
- 基礎數據類型
- 基礎類型轉換
- 格式化輸出
- go指針
- 流程控制語句
- 函數定義
- 匿名函數
- 數組和切片
- map集合
- 結構體
- Interface接口
- 日期處理
- 數學計算
- 正則表達式
- 協程 (并發處理)
- channel
- waitgroup
- mutex (鎖機制)
- websocket
- protobuf
- Redis
- 錯誤處理
- 打包程序
- NSQ消息隊列
- 單元測試
- beego
- 安裝入門
- Gin
- 快速入門
- 路由與控制器
- 處理請求參數
- 表單驗證
- 處理響應結果
- 渲染HTML模版
- 訪問靜態文件
- Gin中間件
- Cookie處理
- Session處理
- Gin上傳文件
- swagger
- pprof性能測試
- GORM
- 入門教程
- 模型定義
- 數據庫連接
- 插入數據
- 查詢數據
- 更新數據
- 刪除數據
- 事務處理
- 關聯查詢
- 屬于 (BELONG TO)
- 一對一 (Has One)
- 一對多 (Has Many)
- 多對多 (Many to Many)
- 預加載 (Preloading)
- 錯誤處理
- 第三方常用插件
- viper 讀取配置文件
- zap 高性能日志
- Nginx代理配置
- Goland 快捷鍵