Go中自定义http.Client需设置超时、连接池、Header、代理、TLS及Cookie:必设Timeout与Transport参数,Header用req.Header.Set(),代理和跳过证书仅限调试,Cookie通过Jar自动管理或手动添加。
在 Go 中使用 http.Client 自定义 HTTP 请求,核心在于控制请求的超时、重试、Header、代理、TLS 配置以及 Cookie 等行为。默认的 http.DefaultClient 很方便,但生产环境通常需要更精细的控制。
避免请求无限挂起或资源耗尽,必须设置超时,并复用连接:
示例:
client := &http.Client{
Timeout: 10 * time.Second,
Transport: &http.Transport{
DialContext: (&net.Dialer{
Timeout: 5 * time.Second,
KeepAlive: 30 * time.Second,
}).DialContext,
TLSHandshakeTimeout: 5 * time.Second,
MaxIdleConns: 100,
MaxIdleConnsPerHost: 100,
IdleConnTimeout: 30 * time.Second,
},
}多数 API 要求 Authorization、User-Agent 或自定义 Header:
*http.Request 上调用 req.Header.Set()
req.SetBasicAuth(user, pass)
Host、Content-Length)由 net/http 自动设置,手动设可能被忽略或报错示例:

req, _ := http.NewRequest("GET", "https://api.example.com/data", nil)
req.Header.Set("User-Agent", "MyApp/1.0")
req.Header.Set("X-API-Key", "abc123")
req.SetBasicAuth("user", "pass")开发调试时可能需走本地代理(如 Charles/Fiddler),或访问自签名 HTTPS 服务:
http.ProxyURL 或 http.ProxyFromEnvironment 设置Transport.TLSClientConfig
InsecureSkipVerify: true
示例:
proxyURL, _ := url.Parse("http://127.0.0.1:8888")
client := &http.Client{
Transport: &http.Transport{
Proxy: http.ProxyURL(proxyURL),
TLSClientConfig: &tls.Config{
InsecureSkipVerify: true, // ⚠️ 仅调试用
},
},
}若需保持登录态,可手动添加 Cookie,或启用自动 Cookie 管理:
req.AddCookie(&http.Cookie{Name: "session_id", Value: "xxx"})
http.CookieJar,配合 cookiejar.New(nil)
Client.Jar
示例(自动管理):
jar, _ := cookiejar.New(nil)
client := &http.Client{
Jar: jar,
}
// 后续请求自动附带服务端 Set-Cookie 返回的 Cookie基本上就这些。关键不是堆砌配置,而是按需开启:超时必设、Header 按协议填、代理和跳证书只在对应场景开、Cookie 看是否需要会话维持。不复杂但容易忽略。