0

0

Go语言如何设置HTTP请求头_HTTP Header设置方法

P粉602998670

P粉602998670

发布时间:2026-01-14 12:43:04

|

850人浏览过

|

来源于php中文网

原创

Go中设置HTTP请求头必须用Header.Set/Add/Del方法,禁用直接赋值;Host、Content-Length等由系统自动管理,手动设置可能无效或出错;Content-Type须与body编码严格匹配;每次请求需独立设置Header,不可复用req对象。

go语言如何设置http请求头_http header设置方法

Go中用http.Request.Header.Set设置请求头最常用

Go标准库http.NewRequest返回的*http.Request对象,其Header字段是http.Header类型(本质是map[string][]string),所有请求头都通过它设置。直接赋值会panic,必须用SetAddDel方法操作。

常见错误是写成req.Header["User-Agent"] = []string{"my-app/1.0"}——这会导致运行时panic,因为底层map未初始化且禁止直接写入。

  • Set(key, value):覆盖已有同名头(如多次调用Set("Accept", "json"),最终只保留最后一次)
  • Add(key, value):追加值(适用于允许重复的头,如Cookie
  • Del(key):删除指定头
req, err := http.NewRequest("GET", "https://api.example.com", nil)
if err != nil {
    log.Fatal(err)
}
req.Header.Set("User-Agent", "my-app/1.0")
req.Header.Set("Accept", "application/json")
req.Header.Add("Cookie", "sessionid=abc123")
req.Header.Add("Cookie", "theme=dark")

哪些HTTP头Go会自动设置或禁止手动覆盖

Go的http.Transport在发送请求前会自动添加或修正部分标准头,比如HostContent-LengthConnection等。如果手动设置这些头,可能被忽略或触发校验失败。

特别注意:Host头由req.URL.Host决定,手动Set("Host", ...)无效;Content-Length由body长度自动计算,手动设错会引发http: invalid Content-Length错误;Transfer-EncodingConnection也受限制。

立即学习go语言免费学习笔记(深入)”;

UP简历
UP简历

基于AI技术的免费在线简历制作工具

下载
  • 可安全设置:User-AgentAuthorizationAcceptContent-Type(POST/PUT时)、X-*自定义头
  • 设了也无效:Host(以URL为准)、Content-Length(除非明确禁用自动计算)
  • 设了可能出错:Transfer-EncodingUpgradeTe(涉及底层连接控制)

POST请求中Content-Type和body编码要匹配

设置Content-Type只是声明“我发的是什么”,但实际body内容必须与之对应,否则服务端解析失败。常见组合有:

  • application/json → body用json.Marshal序列化,再用bytes.NewReader包装
  • application/x-www-form-urlencoded → body用url.Values.Encode()生成字符串
  • multipart/form-data → 必须用mime/multipart包构造,不能手拼
data := map[string]string{"name": "Alice", "age": "30"}
jsonBytes, _ := json.Marshal(data)
req, _ := http.NewRequest("POST", "https://api.example.com/users", bytes.NewReader(jsonBytes))
req.Header.Set("Content-Type", "application/json") // 必须匹配实际body格式

使用http.Client复用连接时头设置的生命周期

每个*http.Request对象的Header是独立的,http.Client本身不保存头信息。所以不能“给client设个默认User-Agent”,而要在每次创建req时设置。若需统一管理,建议封装请求构造函数或使用中间件风格的包装器。

容易忽略的一点:如果复用*http.Request对象(比如修改URL后重发),它的Header仍保留上次的值,可能造成脏数据。务必确认是否需要清空或重置。

  • 不要复用req对象跨多次Do()调用(除非你清楚自己在做什么)
  • 避免在goroutine间共享未加锁的req.Header
  • 若需全局默认头,写一个newRequest()辅助函数,内部统一Set

Header设置看着简单,但和body编码、自动头机制、请求复用耦合紧密,错一处就可能返回400或500而不报具体原因。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

177

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

315

2023.08.02

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6416

2023.06.30

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

34

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号