python绑定udp时使用127.0.0.1作为ip,无法sendto,报错Invalid argument
在 Python 中使用 UDP 套接字进行通信时,绑定127.0.0.1作为 IP 地址后无法使用sendto方法发送数据,可能由多种原因导致
这里是其中一个原因:
127.0.0.1 是本地回环地址,只能用于本机内部的进程间通信,
如果你绑定到 127.0.0.1,那么你的 socket 只能接收来自本机的连接请求,无法与外部网络通信,
发送数据时的socket不能绑定为127.0.0.1, 通常发送数据也不需要绑定ip,只需要指定接收数据的目标ip,
发送数据时如果你不绑定 socket,操作系统会自动分配一个可用的本地 IP 地址和端口
解决办法:创建2个udp socket
- 绑定127.0.0.1可以作为服务器接收数据
- 发送的时候可以不绑定ip,直接指定目标ip发送数据
- 建立2个socket
示例:
import socket
# 创建UDP套接字
server_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# 绑定IP地址和端口
server_address = ('127.0.0.1', 12345)
server_socket.bind(server_address)
# 创建另一个UDP套接字用于发送数据
client_socket = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
# 要发送的数据
message = b'Hello, UDP server!'
# 目标地址
destination_address = ('127.0.0.1', 12345)
# 发送数据
client_socket.sendto(message, destination_address)
# 接收数据
data, address = server_socket.recvfrom(1024)
print(f'Received {data.decode()} from {address}')
# 关闭套接字
client_socket.close()
server_socket.close()
原因2 防火墙或安全软件限制
防火墙或安全软件可能会阻止 UDP 通信。你需要确保防火墙允许 Python 程序进行 UDP 通信,或者临时关闭防火墙进行测试。
Windows 系统:可以在防火墙设置中添加 Python 程序的入站和出站规则,允许其进行 UDP 通信。
Linux 系统:可以使用iptables或ufw命令来开放相应的端口。例如,使用ufw开放 12345 端口:
sudo ufw allow 12345/udp