Go语言通过net/http包提供HTTP客户端功能,使用http.Get可发送简单GET请求,http.Post发送POST请求,或用http.NewRequest构建自定义请求并设置头信息;通过http.Client的Do方法发送请求,需始终调用defer resp.Body.Close()避免资源泄漏;使用io.ReadAll读取响应体,检查resp.StatusCode判断业务成功与否;生产环境应创建带超时的自定义客户端,如设置Timeout或配置Transport以控制连接复用与TLS;注意响应体只能读取一次,重定向默认开启,需区分网络错误与HTTP状态码错误。

Go语言的HTTP客户端功能强大且易于使用,适合发送HTTP请求并处理响应。核心包是
net/http,通过
http.Client和
http.Request可以灵活控制请求的构建与发送。
发送基本HTTP请求
最简单的GET请求可以直接使用
http.Get:
resp, err := http.Get("https://api.example.com/data")
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
对于其他方法如POST、PUT等,可以使用
http.Post或手动构建请求:
resp, err := http.Post("https://api.example.com/submit", "application/json",
strings.NewReader(`{"name":"test"}`))
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
更灵活的方式是使用
http.NewRequest,便于添加头信息或自定义参数:
立即学习“go语言免费学习笔记(深入)”;
req, err := http.NewRequest("POST", "https://api.example.com/submit",
strings.NewReader(`{"name":"test"}`))
if err != nil {
log.Fatal(err)
}
req.Header.Set("Authorization", "Bearer token123")
req.Header.Set("Content-Type", "application/json")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
处理响应数据
请求发送后,需要读取响应体内容。通常使用
io.ReadAll读取
resp.Body:
body, err := io.ReadAll(resp.Body)
if err != nil {
log.Fatal(err)
}
fmt.Println(string(body))
注意
resp.Body必须关闭,避免资源泄漏。即使出错也应调用
defer resp.Body.Close()。
本文档主要讲述的是Service深入分析;我们还是从Service的根本意义分析入手,服务的本质就是响应客户端请求。要提供服务,就必须建立接收请求,处理请求,应答客服端的框架。我想在Android Service设计者也会无时不刻把这个服务本质框图挂在脑海中。从程序的角度,服务一定要存在一个闭合循环框架和请求处理框架。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
检查响应状态码判断请求是否成功:
if resp.StatusCode != http.StatusOK {
fmt.Printf("请求失败: %d\n", resp.StatusCode)
}
自定义客户端与超时控制
默认的
http.Client使用全局默认配置,生产环境建议创建自定义客户端以控制超时:
client := &http.Client{
Timeout: 10 * time.Second,
}
更复杂的场景可配置
Transport实现连接复用、TLS设置等:
client := &http.Client{
Transport: &http.Transport{
MaxIdleConns: 100,
IdleConnTimeout: 30 * time.Second,
TLSHandshakeTimeout: 5 * time.Second,
},
Timeout: 15 * time.Second,
}
常见注意事项
使用Go的HTTP客户端时有几个关键点需注意:
-
始终关闭响应体:无论成功与否,都应调用
resp.Body.Close()
-
处理重定向:默认客户端会自动跟随重定向,可通过设置
CheckRedirect
控制行为 -
避免重复使用Body:响应体是只读一次的流,多次读取需使用
io.TeeReader
或缓存 - 错误类型区分:网络错误和HTTP 4xx/5xx状态码不会返回err,需手动判断StatusCode
基本上就这些。Go的HTTP客户端设计简洁,配合defer和error处理,能高效完成大多数网络请求任务。不复杂但容易忽略细节,比如超时和资源释放,实际使用中要格外注意。









