登录
首页 >  Golang >  Go教程

Golang自定义HTTP头设置教程

时间:2026-02-21 19:36:38 371浏览 收藏

在Go语言中,通过`http.NewRequest`创建请求并灵活运用`Header.Set`和`Header.Add`方法,可以精准控制HTTP请求头——前者用于设置单值字段(如Authorization、User-Agent),后者支持同一键名添加多个值(如Cookie),同时需注意避开Host、Content-Length等受系统保护的禁设字段,必要时可通过`req.Host`绕过限制;掌握这些技巧,不仅能轻松实现身份认证、内容类型声明和客户端伪装,还能为构建健壮、可维护的HTTP客户端打下坚实基础。

Golang HTTP请求Header自定义处理

在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.Gethttp.Post,则无法自定义Header。

添加多个相同Key的Header

某些场景下需要为同一个Key添加多个值(如多个Cookie),应使用Header.Add而非Set

req.Header.Add("Cookie", "session=abc123")
req.Header.Add("Cookie", "theme=dark")

Add会追加值,而Set会覆盖已有值。对于标准Header如User-Agent,多次Set只会保留最后一次。

客户端发送自定义Header的限制

某些Header字段受到浏览器或服务器策略限制,在实际发送时可能被忽略或修改:

  • 禁止设置HostContent-Length等由系统自动管理的Header
  • 敏感Header如ConnectionKeep-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控制权,并合理使用SetAdd。生产环境中建议封装通用Header设置逻辑,避免重复代码。

今天关于《Golang自定义HTTP头设置教程》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>