2

我不知道是网络配置的情况还是我的软件有问题。

我有一个地址为 的设备192.168.4.83。该设备直接连接到我的 pc linux 服务器,地址为192.168.4.11.

我想使用 python 将 UDP 数据包从服务器发送到设备。服务器也在监听响应。我有一个简单的 python 脚本来做到这一点。我发送使用:

    self.sendSocket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    self.sendSocket.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST,1)
    sock.sendSocket.send(msg,('<boradcast>', UDP_PORT))

我收听并绑定到 0.0.0.0。代码很简单:一个线程发送 udp 数据包,另一个线程有 while(1) 循环,它只接收数据包。

这是监听代码:

class CUdp(threading.Thread):
    def __init__(self, log=False):
        threading.Thread.__init__(self)
        self.running = True
        self.listenSocket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        self.listenSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
        self.listenSocket.bind(("", UDP_PORT))
        self.last_time = 0
        self.now = 0
        self.log = log
    def run(self):
        global sent_time
        while(self.running):
            data, addr = self.listenSocket.recvfrom(1024) 
            if data != None:
               recv_time = time.time()
               myprint("[RECV " +  str(datetime.datetime.now()) + "] (len=" + str(len(data)) +") : " +  str(data)+"\n", self.log)

奇怪的是,在wireshark上我可以看到:数据包已经发送192.168.4.11255.255.255.255,并且设备已经响应了这个数据包-数据包192.168.4.83已经发送到255.255.255.255。看来,使用 bind (0.0.0.0, port) 并没有涵盖255.255.255.255. 我迷路了,我没有想法。

ifconfig 是:

eth0      Link encap:Ethernet  HWaddr 2C:41:38:9B:BF:CA  
          inet addr:192.168.4.11  Bcast:192.168.4.255  Mask:255.255.255.0
          inet6 addr: fe80::2e41:38ff:fe9b:bfca/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:34 errors:0 dropped:0 overruns:0 frame:0
          TX packets:413 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000 
          RX bytes:5050 (4.9 KiB)  TX bytes:26688 (26.0 KiB)
          Interrupt:17  

有什么线索吗?

4

1 回答 1

0

假设所有代码都正确编写,这可能只是 linux 防火墙的问题。您可以将您的 IP 地址添加到 iptables,或者如果您处于安全的网络环境中,您可以关闭防火墙:

/etc/init.d/iptables stop

于 2014-01-15T16:18:17.410 回答