使用NewRequest可自定义Header,通过Set设置单值、Add添加多值,注意避免修改受限制字段,并用Client发送请求。

在Go语言中发送HTTP请求时,经常需要对Header进行自定义处理,比如添加认证信息、指定内容类型、伪装User-Agent等。Golang的net/http包提供了灵活的方式来自定义请求头,下面介绍几种常见用法和注意事项。
设置自定义Header
使用http.NewRequest创建请求后,可以通过Header.Set方法添加或修改Header字段:
req, err := http.NewRequest("GET", "https://api.example.com/data", nil)
if err != nil {
log.Fatal(err)
}
req.Header.Set("User-Agent", "MyApp/1.0")
req.Header.Set("Authorization", "Bearer your-token-here")
req.Header.Set("X-Request-ID", "12345")
req.Header.Set("Content-Type", "application/json")
注意:只有在使用http.NewRequest时才能自由设置Header。如果直接使用http.Get或http.Post,则无法自定义Header。
添加多个相同Key的Header
某些场景下需要为同一个Key添加多个值(如多个Cookie),应使用Header.Add而非Set:
立即学习“go语言免费学习笔记(深入)”;
req.Header.Add("Cookie", "session=abc123")
req.Header.Add("Cookie", "theme=dark")
Add会追加值,而Set会覆盖已有值。对于标准Header如User-Agent,多次Set只会保留最后一次。
客户端发送自定义Header的限制
某些Header字段受到浏览器或服务器策略限制,在实际发送时可能被忽略或修改:
- 禁止设置
Host、Content-Length等由系统自动管理的Header - 敏感Header如
Connection、Keep-Alive可能被移除 - 若需强制指定
Host,可通过req.Host字段设置
req.Host = "example.com"
完整示例:带自定义Header的POST请求
client := &http.Client{}
data := strings.NewReader(`{"name": "test"}`)
req, _ := http.NewRequest("POST", "https://httpbin.org/post", data)
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Authorization", "Bearer token123")
req.Header.Set("User-Agent", "Custom-Client/1.0")
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
fmt.Println(string(body))
基本上就这些。关键在于使用NewRequest获得Header控制权,并合理使用Set与Add。生产环境中建议封装通用Header设置逻辑,避免重复代码。










