Go基础HTTP服务器核心是net/http包,需注册路由、定义处理函数并启动监听;支持默认ServeMux或自定义ServeMux,可解析请求参数、返回JSON,并应添加错误处理与优雅关闭。

用 Go 写一个基础 HTTP 服务器非常简单,核心是 net/http 包,不需要额外依赖。关键在于注册路由(或用默认多路复用器)、定义处理函数、启动监听。
使用 http.HandleFunc 快速注册路由
这是最轻量的方式,适合简单服务。Go 内置了默认的 http.ServeMux,你只需传入路径和处理函数:
- 路径支持前缀匹配,例如
"/api/"会匹配所有以该前缀开头的请求 - 处理函数签名必须是
func(http.ResponseWriter, *http.Request) - 响应需手动设置状态码、Header,并调用
w.Write([]byte{...})或fmt.Fprintf
示例:
func main() {http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(200)
w.Header().Set("Content-Type", "text/plain; charset=utf-8")
fmt.Fprint(w, "Hello from Go!")
})
http.HandleFunc("/ping", func(w http.ResponseWriter, r *http.Request) {
json.NewEncoder(w).Encode(map[string]string{"status": "ok"})
})
log.Println("Server starting on :8080")
http.ListenAndServe(":8080", nil)
}
用自定义 ServeMux 实现更清晰的路由管理
显式创建 http.ServeMux 实例,有利于组织代码、复用、加中间件(如日志、CORS),也避免污染默认多路复用器:
立即学习“go语言免费学习笔记(深入)”;
- 用
mux := http.NewServeMux()创建新实例 - 用
mux.HandleFunc(...)注册路由 - 启动时传入该实例:
http.ListenAndServe(":8080", mux)
这样后续可方便替换为第三方路由器(如 gorilla/mux 或 chi),只需改初始化部分。
解析请求参数与返回结构化数据
常见需求包括读取 URL 查询参数、POST 表单、JSON 请求体,以及统一返回 JSON 响应:
-
r.URL.Query().Get("id")获取 query 参数 -
r.FormValue("name")自动解析 POST 表单或 query(推荐用于简单场景) - 读取 JSON 请求体:先
r.ParseBody()(对 JSON 非必须,但确保 Body 可读),再用json.NewDecoder(r.Body).Decode(&v) - 返回 JSON:设 Header
"Content-Type: application/json",再用json.NewEncoder(w).Encode(data)
注意:若未显式设置状态码,Go 默认返回 200;出错时建议主动调用 w.WriteHeader(400) 等。
添加基本错误处理与优雅关闭
生产环境需捕获 panic、处理监听失败、支持信号中断:
- 用
http.Server结构体封装,便于控制超时、TLS、关闭逻辑 - 监听前检查端口是否被占用,避免静默失败
- 监听时用
server.ListenAndServe(),关闭时调用server.Shutdown(context.WithTimeout(...)) - 监听 goroutine 中 recover panic,防止整个服务崩溃
不复杂但容易忽略。











