使用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语言免费学习笔记(深入)”;
网易人工智能
网易数帆多媒体智能生产力平台
206 查看详情
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设置逻辑,避免重复代码。
以上就是Golang HTTP请求Header自定义处理的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1138381.html
微信扫一扫
支付宝扫一扫