首先,一个警告。pickle允许执行任意代码。不要使用这个来接受任意连接,最好使用加密来确保您只交换可信的数据。即使这样,也可以考虑使用更安全的交换格式。在
接下来,考虑UDP数据包的大小是有限的。您需要确保pickle数据足够小,能够容纳UDP数据包(最大有效负载大小为65507字节)。至少当你收到包裹时,你会知道你有所有的数据。使用65535作为缓冲区大小,以确保可以完全接收大数据包。在
发送时,请确保不要超过大小限制:MAX_UDP_SIZE = 65507 # https://en.wikipedia.org/wiki/User_Datagram_Protocol
a = pickle.dumps(p)
if len(a) > MAX_UDP_SIZE:
raise ValueError('Message too large')
s.sendto(a, (host, port))
另一方面,使用^{}将pickle数据流转换回一个对象:
^{pr2}$
我强烈建议您至少验证addr是可信的,否则您可以随意执行任意代码。65507字节有足够的空间发送pickle来控制进程。在
如果您需要发送更多数据,那么您将需要使用TCP而不是UDP,因为您必须按照特定的顺序跨数据发送,分布在多个数据包中,并且需要所有数据包都到达接收端;TCP提供了这一层的可靠性。在这一点上,您必须在pickle前面加上一个固定数量的字节,编码pickle的大小,这样就可以确保在另一端再次读取相同数量的数据。在