在go语言中处理http请求需掌握Header与Body操作。1. 读取Header用req.Header.Get(key)获取单值,多值则用req.Header[key]切片;2. 设置响应Header需在写入Body前调用w.Header().Set(“Key”, “Value”);3. 读取Body通过req.Body.ReadAll()解析jsON或表单数据。

在Go语言中处理HTTP请求时,正确读取和操作Header与Body是构建Web服务的基础能力。无论是开发API接口、中间件,还是代理服务,都需要对请求的头部信息和主体内容进行精确控制。下面从实际使用角度出发,详细说明golang中如何高效处理HTTP请求的Header和Body。
读取与设置HTTP Header
HTTP Header用于传递元数据,如认证信息、内容类型、客户端信息等。在Golang的net/http包中,Header以键值对形式存在,支持多值。
获取Header字段:通过req.Header.Get(key)获取指定字段的值(返回第一个值),适合大多数单值场景,如Content-Type。
若某个字段有多个值(如Set-cookie),可用req.Header[key]获取字符串切片。
立即学习“go语言免费学习笔记(深入)”;
设置Header:在响应中可通过w.Header().Set(“Key”, “Value”)写入Header。注意必须在调用w.WriteHeader()或写入Body前完成设置,否则无效。
常见操作示例:
- 检查请求内容类型:contentType := req.Header.Get(“Content-Type”)
- 添加自定义响应头:w.Header().Set(“X-app-Version”, “1.0.0”)
- 设置CORS头:w.Header().Set(“access-Control-Allow-Origin”, “*”)
解析与读取请求Body
请求Body通常携带客户端提交的数据,如json、表单或文件。Golang中通过req.Body访问,其类型为或
var data map[string]interface{} if err := json.Unmarshal(body, &data); err != nil { http.Error(w, "JSON解析失败", http.StatusBadRequest) return }
若使用结构体绑定,建议定义具体类型提升可维护性。
处理Body多次读取的场景
某些场景如下游转发、日志记录、签名验证等,需要多次读取Body。此时原始重建。
示例代码:
body, _ := io.ReadAll(req.Body) req.Body = io.NopCloser(bytes.NewBuffer(body)) // 重新赋值以便后续读取 // 此时可安全地再次读取req.Body
在中间件中常用于记录请求日志或做前置校验,避免影响后续处理器。
结合Header与Body的实用技巧
实际开发中,Header与Body常需配合使用。例如根据application/json时,按JSON解析
对于API鉴权,常从Header中提取的单次读取特性,并合理利用标准库提供的工具。不复杂但容易忽略细节,写代码时多注意边界处理即可。