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