Go基础HTTP服务器核心是net/http包,需注册路由、定义处理函数并启动监听;支持默认ServeMux或自定义ServeMux,可解析请求参数、返回JSON,并应添加错误处理与优雅关闭。
用 Go 写一个基础 HTTP 服务器非常简单,核心是 net/http 包,不需要额外依赖。关键在于注册路由(或用默认多路复用器)、定义处理函数、启动监听。
http.HandleFunc 快速注册路由这是最轻量的方式,适合简单服务。Go 内置了默认的 http.ServeMux,你只需传入路径和处理函数:
"/api/" 会匹配所有以该前缀开头的请求func(http.ResponseWriter, *http.Request)
w.Write([]byte{...}) 或 fmt.Fprintf
示例:
func main() {ServeMux 实现更清晰的路由管理显式创建 http.ServeMux 实例,有利于组织代码、复用、加中间件(如日志、CORS),也避免污染默认多路复用器:
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(推荐用于简单场景)r.ParseBody()(对 JSON 非必须,但确保 Body 可读),再用 
json.NewDecoder(r.Body).Decode(&v)
"Content-Type: application/json",再用 json.NewEncoder(w).Encode(data)
注意:若未显式设置状态码,Go 默认返回 200;出错时建议主动调用 w.WriteHeader(400) 等。
生产环境需捕获 panic、处理监听失败、支持信号中断:
http.Server 结构体封装,便于控制超时、TLS、关闭逻辑server.ListenAndServe(),关闭时调用 server.Shutdown(context.WithTimeout(...))
不复杂但容易忽略。