当前位置: 首页 > article >正文

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

  1. 绑定127.0.0.1可以作为服务器接收数据
  2. 发送的时候可以不绑定ip,直接指定目标ip发送数据
  3. 建立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

http://www.kler.cn/a/561772.html

相关文章:

  • 无限宽度神经网络的神经正切核(Neural Tangent Kernel, NTK)
  • 多线程进阶 : 八股文面试题 一 [Java EE 多线程 锁和死锁相关问题]
  • vscode设置自动换行
  • 【WordPress】发布文章时自动通过机器人推送到钉钉
  • Pi币今日成交价格飙升,XBIT去中心化交易所助力新浪潮
  • MySQL知识
  • vue3.0将后端返回的word文件流转换为pdf并导出+html2pdf.js将页面导出为pdf
  • keil中出现Error_Handler错误的解决方法
  • 云计算模型和边缘计算模型
  • ubuntu 源码编译ffmpeg
  • 【JavaScript】《JavaScript高级程序设计 (第4版) 》笔记-Chapter23-JSON
  • 深入解析 synchronized 锁升级:从偏向锁到重量级锁的设计哲学
  • 面试之《nodejs中,网络请求时stream和json的区别》
  • 基于STM32的智能工业生产线质量检测系统
  • Transformers框架微调Qwen和DeepSeek
  • 6.6.3 SQL数据查询(一)
  • 算法题训练 ——— NC313 两个数组的交集
  • sklearn中的决策树
  • 以绘图(绘制点、直线、圆、椭圆、多段线)为例子 通过设计模式中的命令模式实现
  • ubuntu20.04 突破文件数限制