<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                [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() }) ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看