答案:go语言通过http.Request.Header读取请求头,使用Get方法不区分大小写获取值;响应头通过ResponseWriter.Header()设置,用Set添加单值、Add添加多值,需在WriteHeader前调用;支持多值头部如Cookie和Accept,可用切片或Values方法处理。

在go语言中处理HTTP请求Header非常直接,主要通过*http.Request对象的Header字段进行操作。这个字段是一个http.Header类型,底层是map[String][]string,支持多值头部。下面介绍几种常见场景和处理方式。
读取请求Header
在HTTP处理器中,可以通过r *http.Request参数访问请求头信息。
例如,获取User-Agent或自定义头部X-API-Key:
func handler(w http.ResponseWriter, r *http.Request) { userAgent := r.Header.Get("User-Agent") apiKey := r.Header.Get("X-API-Key") // 注意:Get方法返回第一个值,忽略大小写 fmt.Fprintf(w, "User-Agent: %sn", userAgent) fmt.Fprintf(w, "API Key: %sn", apiKey) }
说明:Header.Get(key)是推荐方式,它不区分键的大小写,并返回对应的第一个值。如果使用r.Header["Key"]会区分大小写且暴露全部值(slice),不符合标准做法。
立即学习“go语言免费学习笔记(深入)”;
设置响应Header
向客户端返回响应时,使用http.ResponseWriter的Header()方法设置头部。
func handler(w http.ResponseWriter, r *http.Request) { w.Header().Set("Content-Type", "application/JSon") w.Header().Set("X-Server", "Go-Server") // 如果要设置多个同名头部(如Set-Cookie),使用Add w.Header().Add("Set-Cookie", "Session=abc123") w.Header().Add("Set-Cookie", "theme=dark") w.WriteHeader(http.StatusOK) w.Write([]byte(`{"status": "ok"}`)) }
注意:必须在调用Write或WriteHeader之前设置Header,否则无效。
检查是否存在某个Header
有时需要判断某个Header是否被发送。可以使用Get配合空值判断,或者直接查map:
if contentType := r.Header.Get("Content-Type"); contentType != "" { fmt.Println("Content-Type is set:", contentType) } // 或者检查是否存在(不关心值) if _, exists := r.Header["Authorization"]; exists { fmt.Println("Authorization header present") }
处理多值Header
某些Header可能包含多个值,比如Accept或自定义的X-forwarded-For。
使用Header.Values获取所有值:
accepts := r.Header["Accept"] // 直接访问slice // 或者 accepts = r.Header.Values("Accept") for _, v := range accepts { log.Println("Accept:", v) } </font>
提示:大多数情况下用Get就够了,只有在明确需要所有值时才用切片访问。
基本上就这些。Go的标准库设计简洁,Header操作直观,关键是记住Get、Set、Add这几个核心方法的使用时机。


