package main import ( "encoding/binary" "errors" "fmt" "net" "time" "github.com/google/gopacket" "github.com/google/gopacket/pcap" ) func errCheck(err error) { if err != nil { panic(err) } return } func listenDiscoverResponse() { handle, err := pcap.OpenLive("any", int32(1600), true, pcap.BlockForever) errCheck(err) handle.SetBPFFilter("udp and port 8850") packets := gopacket.NewPacketSource(handle, handle.LinkType()).Packets() for pkt := range packets { fmt.Printf("%s\n", pkt.NetworkLayer().NetworkFlow().Src()) } return } func toMaxHost(n *net.IPNet) (net.IP, error) { if n.IP.To4() == nil { return net.IP{}, errors.New("IP address is not IPv4") } ip := make(net.IP, len(n.IP.To4())) binary.BigEndian.PutUint32(ip, binary.BigEndian.Uint32(n.IP.To4())|^binary.BigEndian.Uint32(net.IP(n.Mask).To4())) return ip, nil } func bcastAddresses() ([]string) { var addrs []string = nil interfaceInfo, _ := net.Interfaces() for i := 0; i < len(interfaceInfo); i++ { addr, err := interfaceInfo[i].Addrs() errCheck(err) for j := 0; j < len(addr); j++ { _, ipNet, _ := net.ParseCIDR(addr[j].String()) bcast, err := toMaxHost(ipNet) if err != nil { } else { addrs = append(addrs, bcast.String()) } } } return addrs } func main() { sendAddrs := bcastAddresses() go listenDiscoverResponse() time.Sleep(1 * time.Second) for i := 0; i < len(sendAddrs); i++ { remoteAddr := sendAddrs[i] + ":8888" remote, err := net.ResolveUDPAddr("udp4", remoteAddr) errCheck(err) conn, err := net.DialUDP("udp4", nil, remote) errCheck(err) defer conn.Close() _, err = conn.Write([]byte(conn.LocalAddr().String())) errCheck(err) } time.Sleep(30 * time.Second) }