Définition de IP_MULTICAST_LOOP pour les connexions UDP multidiffusion dans Go
Sous Windows, l'utilisation de net.ListenMulticastUDP() pour définir l'indicateur IP_MULTICAST_LOOP n'est pas prise en charge, car mentionné dans le message d'erreur. Pour activer l'envoi et la réception de paquets multidiffusion sur la machine locale, des méthodes alternatives sont nécessaires.
Utilisation de golang.org/x/net/ipv4
Le golang.org/ Le package x/net/ipv4 offre une prise en charge multidiffusion plus complète. Il permet une manipulation directe du flag IP_MULTICAST_LOOP :
MulticastLoopback Flag
La fonction MulticastLoopback dans ipv4 récupère le paramètre actuel de l'indicateur IP_MULTICAST_LOOP. Pour activer le bouclage, appelez SetMulticastLoopback(true).
Exemple
package main import ( "fmt" "net" "golang.org/x/net/ipv4" ) func main() { ipv4Addr := &net.UDPAddr{IP: net.IPv4(224, 0, 0, 251), Port: 5352} conn, err := net.ListenUDP("udp4", ipv4Addr) if err != nil { fmt.Printf("ListenUDP error %v\n", err) return } pc := ipv4.NewPacketConn(conn) // Assume a network interface named "wlan" iface, err := net.InterfaceByName("wlan") if err != nil { fmt.Printf("Can't find specified interface %v\n", err) return } if err := pc.JoinGroup(iface, &net.UDPAddr{IP: net.IPv4(224, 0, 0, 251)}); err != nil { return } // Enable multicast loopback if err := pc.SetMulticastLoopback(true); err != nil { fmt.Printf("Error setting multicast loopback: %v\n", err) } }
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!