我有一个在我的专用网络上运行的UDP服务器 . 我有一个超出NAT的设备,它通过公共IP将UDP数据包发送到我的服务器 . 我能够收到UDP数据包,解析它们,我可以查看有效负载,src和dest端口 . 现在我需要向该设备发送ACK消息,以便我捕获了ip和端口号并向其发送UDP数据包 . 但我无法在该设备中查看任何UDP数据包 .
我的问题是,我的设备超出NAT,我得到的IP地址和端口号是NAT还是实际的设备?
如何通过NAT将UDP数据包发送到该设备?
您从数据包中识别的IP和端口是NAT为客户端创建映射的IP和端口 . 简而言之,它是设备所连接的NAT的IP和端口 .
您需要回复服务器从客户端收到的数据包中检测到的IP和端口 . 更清楚的是,你需要实现 UDP Holepunching .
我想您应该首先了解有关连接到NAT下工作的设备的网络问题 . 各种 RFC 可用于 NAT Traversal 和 UDP Punching .
以下是一些消息来源:
http://en.wikipedia.org/wiki/Network_address_translation
http://en.wikipedia.org/wiki/UDP_hole_punching
http://tools.ietf.org/html/rfc4787
https://tools.ietf.org/html/rfc5128
1 回答
您从数据包中识别的IP和端口是NAT为客户端创建映射的IP和端口 . 简而言之,它是设备所连接的NAT的IP和端口 .
您需要回复服务器从客户端收到的数据包中检测到的IP和端口 . 更清楚的是,你需要实现 UDP Holepunching .
我想您应该首先了解有关连接到NAT下工作的设备的网络问题 . 各种 RFC 可用于 NAT Traversal 和 UDP Punching .
以下是一些消息来源:
http://en.wikipedia.org/wiki/Network_address_translation
http://en.wikipedia.org/wiki/UDP_hole_punching
http://tools.ietf.org/html/rfc4787
https://tools.ietf.org/html/rfc5128