gpt4 book ai didi

python - 如何从 Twisted 中的 datagramReceived 中获取多播组地址?

转载 作者:行者123 更新时间:2023-11-28 16:48:22 25 4
gpt4 key购买 nike

这是来自 Twisted 的以下代码示例,用于处理多播接收。我目前正在用同一个客户端收听许多组,我希望能够打印出某个数据报包来自哪个组。我认为这可以从 datagramReceived 的地址参数中接收;然而,这只给我一个元组,其中包含一个组绑定(bind)到的本地 ip 和端口,而不是组本身的地址。

问题:如何在 Twisted 协议(protocol)/API 中打印数据报来源的多播地址?

from twisted.internet.protocol import DatagramProtocol
from twisted.internet import reactor


class MulticastPingClient(DatagramProtocol):

def startProtocol(self):
# Join the multicast address, so we can receive replies:
self.transport.joinGroup("228.0.0.5")
self.transport.joinGroup("229.0.2.11")
self.transport.joinGroup("221.3.3.3")
# Send to 228.0.0.5:8005 - all listeners on the multicast address
# (including us) will receive this message.
self.transport.write('Client: Ping', ("228.0.0.5", 8005))

def datagramReceived(self, datagram, address):
print "Datagram %s received from %s" % (repr(datagram), repr(address))


reactor.listenMulticast(8005, MulticastPingClient(), listenMultiple=True)
reactor.run()

最佳答案

不幸的是,套接字 APIs Twisted wraps(通过 Python 的标准库)不提供此信息。我建议为每个多播组使用一个单独的 DatagramProtocol,并为每个组监听不同的端口。尽管有人仍然可以将 UDP 数据报直接发送到该端口,但您无法将其与多播区分开来。

我有一个模糊的内存表明 recvmsg() API 确实提供了必要的信息,尽管我没有时间验证这一点。 Twisted 12.1 开始有一个 recvmsg() 包装器,因此这可能是一种将此功能添加到 Twisted(或您的代码)的可能方法,但需要做更多的工作。

关于python - 如何从 Twisted 中的 datagramReceived 中获取多播组地址?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11400494/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com