您的位置:首页 >Go 中 UDP 组播发送与解析 JSON 方法
发布于2026-04-18 阅读(0)
扫一扫,手机访问

本文详解如何使用 Go 语言通过 UDP 组播发送 JSON 消息,并在接收端正确反序列化为 map[string]interface{},涵盖 json.Marshal/json.Unmarshal 的正确用法、字节切片边界处理及常见陷阱。
本文详解如何使用 Go 语言通过 UDP 组播发送 JSON 消息,并在接收端正确反序列化为 `map[string]interface{}`,涵盖 `json.Marshal`/`json.Unmarshal` 的正确用法、字节切片边界处理及常见陷阱。
在 Go 中实现 UDP 组播的 JSON 通信,关键在于发送端正确编码、接收端精准解码,尤其需注意原始字节流的完整性与边界控制。
原代码中 c.Write([]byte(myjson)) 是冗余的,因为 json.Marshal() 已返回 []byte 类型:
// ✅ 推荐写法:避免无意义转换 c.Write(myjson) // myjson 类型即为 []byte // ❌ 不必要转换(且易引发误解) c.Write([]byte(myjson)) // 编译报错:cannot convert []byte to []byte
同时,请确保目标地址为合法的 IPv4 组播地址(如 224.0.0.1:8080)且网络接口支持组播;若需跨网段,还需设置 TTL(见后文注意事项)。
接收时 b[:n] 是关键——n 表示实际读取的字节数,而 b 全长(如 maxDatagramSize)可能包含填充的零值。若直接对整个 b 解析,会因尾部 \x00 导致 invalid character '\x00' 错误:
b := make([]byte, maxDatagramSize)
n, src, err := l.ReadFromUDP(b)
if err != nil {
log.Printf("Read error from %v: %v", src, err)
continue
}
// ✅ 正确:仅解析前 n 个有效字节
var payload map[string]interface{}
if err := json.Unmarshal(b[:n], &payload); err != nil {
log.Printf("JSON decode failed from %v: %v", src, err)
continue
}
messages <- payload // 直接发送 map,非 string!
log.Printf("Received: %+v from %v", payload, src)const maxDatagramSize = 65536
func sendMulticast(addrStr string, messages chan interface{}) {
addr, _ := net.ResolveUDPAddr("udp", addrStr)
conn, _ := net.DialUDP("udp", nil, addr)
defer conn.Close()
for msg := range messages {
data, err := json.Marshal(msg)
if err != nil {
log.Printf("Marshal error: %v", err)
continue
}
if _, err := conn.Write(data); err != nil {
log.Printf("Send error: %v", err)
}
time.Sleep(2 * time.Second)
}
}
func serveMulticast(addrStr string, messages chan interface{}) {
addr, _ := net.ResolveUDPAddr("udp", addrStr)
iface, _ := net.InterfaceByName("en0") // 替换为你的活跃网卡名
conn, _ := net.ListenMulticastUDP("udp", iface, addr)
conn.SetReadBuffer(maxDatagramSize)
defer conn.Close()
buf := make([]byte, maxDatagramSize)
for {
n, src, err := conn.ReadFromUDP(buf)
if err != nil {
log.Printf("Read error: %v", err)
continue
}
var m map[string]interface{}
if err := json.Unmarshal(buf[:n], &m); err != nil {
log.Printf("Unmarshal error from %v: %v", src, err)
continue
}
messages <- m
log.Printf("✅ Decoded %d bytes from %v: %+v", n, src, m)
}
}通过严格遵循字节边界、合理使用标准库序列化工具,即可构建稳定可靠的 Go 组播 JSON 通信链路。
上一篇:优酷我的影片怎么查看
下一篇:百度地图语音切换失败解决方法
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9