UDP服务器和客户端在不同局域网就不能正常通信了,为什么?? 我自己写了一个UDP的服务器程序,但发现客户端和服务器只能在局域网内运行;如果客户端在另外一个局域网就不行了,客户端发送的数据服务器倒可以收到,但服务器发送出去的数据客户端根本收不到,谁知道这是怎么回事? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 因为在接收与发送端都在局域网内,所以经过NAT端口映射后,你绑定的端口对于外网对应iP来说端口就不一样了了。例如:你的机器IP为 192.168.0.22 端口为 5000 但当你通过绑定的这个端口与外网机器通信时,你所在的路由NAT会把你的这个5000 端口映射到另一端口中与别人通信,比如 2768 等等,对方得到的就是一个外网IP和2768端口了所以你写的程序自然也就不可能跟你192.168.0.22这个IP的5000端口通信了。要解决这个问题可以参考NAT穿透技术进行点对点UDP或者使用转发 http://www.cnblogs.com/openso2009/archive/2009/09/23/1572448.html111) Full Cone这种NAT内部的机器A连接过外网机器C后,NAT会打开一个端口.然后外网的任何发到这个打开的端口的UDP数据报都可以到达A.不管是不是C发过来的.例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)任何发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)2) 2) Restricted Cone这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用任何端口和A通信.其他的外网机器不行.例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)任何从C发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)3) 3)Port Restricted Cone这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用原来的端口和A通信.其他的外网机器不行.例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)C(202.88.88.88:2000)发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)以上三种NAT通称Cone NAT.我们只能用这种NAT进行UDP打洞. udp 有c s 之分吗 API Hook Detours技术 求助! 关于用CRecordset里的Edit()进行修改的问题 学习的激情受到打击,前辈请帮我分析分析吧(十分诚恳的请教+在线等待) 不知道有没有“模拟”打印机的软件? windows进程管理工具设计与实现 c/c++实现 vc工具 超级简单问题,求如何在程序中自动关掉已经生成的对话框的代码 PRO*C程序预编译通过,但是联编出现LNK2001问题 (高分求助 !) 简单问题,因为刚学计算机,简直是送分!! 高手给指点指点这条语句!!急 把一个64byte的二进制数字变成十进制的字符串 (急,在线等。。)基于电子认证技术的编程(数字签名技术)
111) Full Cone
这种NAT内部的机器A连接过外网机器C后,NAT会打开一个端口.然后外网的任何发到这个打开的端口的UDP数据报都可以到达A.不管是不是C发过来的.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)
任何发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)
2) 2) Restricted Cone
这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用任何端口和A通信.其他的外网机器不行.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)
任何从C发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)3) 3)Port Restricted Cone
这种NAT内部的机器A连接过外网的机器C后,NAT打开一个端口.然后C可以用原来的端口和A通信.其他的外网机器不行.
例如 A:192.168.8.100 NAT:202.100.100.100 C:292.88.88.88
A(192.168.8.100:5000) -> NAT(202.100.100.100 : 8000) -> C(292.88.88.88:2000)
C(202.88.88.88:2000)发送到 NAT(202.100.100.100:8000)的数据都可以到达A(192.168.8.100:5000)以上三种NAT通称Cone NAT.我们只能用这种NAT进行UDP打洞.