Go中搭建WebSocket环境需选用gorilla/websocket库,编写HTTP升级handler实现连接,前端用浏览器Console测试,注意跨域、握手失败和连接闪断等常见问题。
在 Go 中搭建 WebSocket 开发环境并不复杂,核心是选对库、写好服务端基础结构、配好依赖管理,并确保能跑通一个可交互的连接示例。下面分几步说清楚关键配置点。
Go 官方标准库不直接支持 WebSocket,推荐使用社区成熟度高、维护活跃的 gorilla/websocket —— 它是目前最广泛采用的实现,文档全、示例多、兼容性好。
go get github.com/gorilla/websocket
go.mod 中已正确记录该依赖不需要框架,几行代码就能启动一个支持升级 HTTP 到 WebSocket 的服务:
http.HandleFunc 注册一个路径(如 /ws)upgrader.Upgrade(r, w, nil) 完成协议切换*websocket.Conn 收发消息(Wri
teMessage / ReadMessage)conn.Close()
不用额外工具,浏览器控制台就能测试:
const ws = new WebSocket("ws://localhost:8080/ws"); ws.onopen = () => ws.send("hello"); ws.onmessage = e => console.log(e.data);
Connection closed before receiving a handshake response,检查服务端是否真的调用了 Upgrade,且路径和协议(ws://)匹配开发初期最容易卡在这几个地方:
file:// 打开会触发 CORS;建议用 live-server 或简单起个静态服务(go run -m http.FileServer)Upgrade 必须是第一个响应,不能有其他 WriteHeader 或 Write
defer conn.Close(),且读写操作加了 SetReadDeadline/SetWriteDeadline 防止阻塞基本上就这些。环境搭起来很快,重点是理解“HTTP 升级”这个机制,而不是堆功能。跑通一次收发,后面加广播、心跳、鉴权就顺了。