我自己写了一个UDP的服务器程序,
但发现客户端和服务器只能在局域网内运行;
如果客户端在另外一个局域网就不行了,
客户端发送的数据服务器倒可以收到,
但服务器发送出去的数据客户端根本收不到,
谁知道这是怎么回事?

解决方案 »

  1.   

    因为在接收与发送端都在局域网内,所以经过NAT端口映射后,你绑定的端口对于外网对应iP来说端口就不一样了了。例如:你的机器IP为 192.168.0.22 端口为 5000 但当你通过绑定的这个端口与外网机器通信时,你所在的路由NAT会把你的这个5000 端口映射到另一端口中与别人通信,比如 2768 等等,对方得到的就是一个外网IP和2768端口了所以你写的程序自然也就不可能跟你192.168.0.22这个IP的5000端口通信了。要解决这个问题可以参考NAT穿透技术进行点对点UDP或者使用转发
      

  2.   

    http://www.cnblogs.com/openso2009/archive/2009/09/23/1572448.html
    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打洞.
      

  3.   

    udp 有c  s 之分吗