golang提交get,post请求(带参数)

先创建一个解析请求的服务

package main

import (
	"fmt"
	"github.com/gin-gonic/gin"
)

func main() {
	router := gin.Default()
	router.POST("/post", PostFunc)
	router.GET("/get", GetFunc)
	router.Run(":5000")
}

func GetFunc(c *gin.Context) {
	name := c.Query("name")
	age := c.Query("age")
	uri:=c.Request.URL.RawQuery
	fmt.Println(name)
	fmt.Println(age)
	fmt.Println(uri)
}

func PostFunc(c *gin.Context) {
	buf := make([]byte, 1024)
	n, _ := c.Request.Body.Read(buf)
	fmt.Println(string(buf[0:n]))
}

下面是提交请求的功能

package main

import (
	"bytes"
	"encoding/json"
	"fmt"
	"io/ioutil"
	"net/http"
	"strings"
	"unsafe"
)

func main() {
	fmt.Println(getReq("zhangsan", "18"))
	postReq("lisi", 19)
	postReqJson1()
	var j JsonPost
	(*JsonPost).postReqJson2(&j)  // 隐式调用
	
}

func getReq(name string, age string) string {
	client := &http.Client{}

	req, err := http.NewRequest("GET", "http://localhost:5000/get",
		nil)
	if err != nil {
		panic(err)
	}
	query := req.URL.Query()
	query.Add("name", name)
	query.Add("age", age)
	req.URL.RawQuery = query.Encode()

	resp, err := client.Do(req)

	defer resp.Body.Close()

	body, err := ioutil.ReadAll(resp.Body)
	if err != nil {
		panic(err)
	}

	resdata := string(body)
	return resdata

}

func postReq(name string, age int) {
	client := &http.Client{}

	req, err := http.NewRequest("POST", "http://localhost:5000/post",
		strings.NewReader(fmt.Sprintf("name=%s&age=%d", name, age)))
	if err != nil {
		panic(err)
	}

	req.Header.Set("Content-Type", "application/x-www-form-urlencoded")

	resp, err := client.Do(req)

	defer resp.Body.Close()

}

// 通过json提交post
func postReqJson1() {
	url := "http://localhost:5000/post"
	name := "wangwu"
	age := 20

	//json序列化
	post := fmt.Sprintf("{\"name\":%s,\"age\":%d}", name, age)
	fmt.Println(url, "post", post)

	var jsonStr = []byte(post)

	req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonStr))

	req.Header.Set("Content-Type", "application/json")

	client := &http.Client{}
	resp, err := client.Do(req)
	if err != nil {
		panic(err)
	}
	defer resp.Body.Close()

	fmt.Println("status", resp.Status)
	fmt.Println("response:", resp.Header)
	body, _ := ioutil.ReadAll(resp.Body)
	fmt.Println("response Body:", string(body))

}

type JsonPost struct {
}

func (jp *JsonPost) postReqJson2() {
	post := make(map[string]interface{})
	post["name"] = "王柳"
	post["age"] = 21
	bytesData, err := json.Marshal(post)
	if err != nil {
		fmt.Println(err.Error())
		return
	}
	reader := bytes.NewReader(bytesData)
	url := "http://localhost:5000/post"
	request, err := http.NewRequest("POST", url, reader)
	if err != nil {
		fmt.Println(err.Error())
		return
	}
	request.Header.Set("Content-Type", "application/json;charset=UTF-8")
	client := http.Client{}
	resp, err := client.Do(request)
	if err != nil {
		fmt.Println(err.Error())
		return
	}
	respBytes, err := ioutil.ReadAll(resp.Body)
	if err != nil {
		fmt.Println(err.Error())
		return
	}
	//byte数组直接转成string,优化内存
	str := (*string)(unsafe.Pointer(&respBytes))
	fmt.Println(*str)

}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,Go语言是一种高效的编程语言,适用于并发编程和网络编程。在网络编程中,httpclient是一个常用的工具,它可以发送HTTP请求并接收响应。 在Go语言中获取httpclient有两种方式:一种是使用内置的net/http包,另一种是使用第三方库。 使用内置的net/http包可以轻松地创建httpclient。我们可以通过以下代码创建一个httpclient: ```go func main() { client := &http.Client{} req, err := http.NewRequest("GET", "https://www.example.com", nil) if err != nil { log.Fatal(err) } resp, err := client.Do(req) if err != nil { log.Fatal(err) } defer resp.Body.Close() } ``` 通过上述代码,我们可以看到,我们使用了http.Client{}来创建httpclient,然后使用http.NewRequest()方法创建一个get请求请求参数包括请求的方法(GET、POST等)、URL、body等。发送请求后,我们可以使用client.Do()方法获取响应,最后记得关闭响应体。 如果需要更多的控制和配置,我们可以使用http.Transport{}来创建定制的httpclient,例如超时时间、代理等。 此外,我们还可以使用第三方库(如Go Resty或Gentleman)来获取httpclient。这些库提供了一些更方便的API和功能,例如自动管理和维护cookie、使用连接池等。使用这些库可以加快我们的开发速度,但需要学习并掌握它们的API和用法。 总而言之,在Go语言中获取httpclient非常简单,我们可以使用内置的net/http包或第三方库,在开发过程中灵活应用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值