前言:
       最近我用java做了一个C/S的类似QQ之类的IM系统(即时通讯系统),遇到了不能跨局域网通讯的问题,经过在网上,和书上查阅了一些资料,了解了一些情况,现在就总结一下我的解决方案吧(本人也是在不断错误中学习,如果有什么不对的地方,请大家多多指教)。

问题描述:
         一般情况下,只能在同一个子网即同一个虚拟局网里通讯,或者子网访问外网,外网访问不了内网。因为虚拟局域网相对于外网都是透明的,所以外网是不能直接访问子网,举个例子:校园网里的学生信息管理系统(MIS),需要是校园网里面的IP地址才能访问,校园网以外的IP是不能访问,这样的做法的好处不用我多说吧。。
而即时通讯需要相互交流信息,所以需要相互都能访问到,问题是:如何跨子网通讯?

问题分析:

2.ClientA在子网,ClientB在外网

者IP的数据包;如果ClientA发送数据包给ClientB,ClientB接受数据包的IP来源并不是ClientA,而已中转站(路由器)的IP。

解决方案:

单,这里就不多说了。

吧。
1)NAT
这里默认是用NAT,端口号没有转换,如果是NAPT,实现的原理也是差不多的,只是细节不同。

关于第二种情况,原理如下:
NATA:路由器对外的wlanIP:168.38.2.2;路由器对内的lanIP:192.168.1.10

1.首先,A(内网IP)先向B(外网IP)发送UDP包,NAT会产生session,存放192.168.1.10-- >168.38.2.225的映射关系

2.接下来,只要B把信息发给NATA,NATA会自动把信息转发给A

关于第三种情况,原理如下:

务器,记录了所有客户端的真实IP(如果是内网IP就记录内网IP),我是用TCP来实现客户端和服务器的通讯,这里要用到了TCP穿透,这里先不讲,最后总结说一下。

或者如图:(ps:图片是网上下载的)

务器--客户端之间可以相互通讯。客户端会向客户端发送自身的真实IP(如A:192.168.1.110),服务器接受到这信息之后,同时也会知道信息源的IP(如:NATA的外网IP:210.38.196.110),因为接受方总能知道信息包的最直接来源。此时,服务器就记录了ClientA的IP、NATA外网IP和ClientB的IP、NATB外网IP。

要想A<------>B之间无需经过第三方的通讯,必须在NATA中为B打个洞,在NATB中为A打个洞。

NATB发送到NATA的,都会转发到A子网中,此过程叫NATA为B打洞。同理NATB也可以为A打洞。

具体过程:server会发送信息告知A,B的NATB的外网IP;告知B,A的NATA的外网IP。这样子,A可以先发送一个数据包到NATB(外网IP:210.38.196.30),NATA会生成一个session记录A————>NATB的映射关系。数据包到达NATB时,NATB因为还未为A打洞,会丢包。然后B向NATA(外网IP:210.38.196.110)发送数据包,NATB会生成一个session记录B————>NATA的映射关系。此时,NATA接受到来自NATB的数据包,会查找下session映射,发现有A————>NATB的映射关系,会把包转发给A。只要A再发信息给NATB时,NATB也会根据session来转发给B。双方打洞完成。

利用第三方服务器来帮P2P对等点之间的UDP打洞,是比较全面的方案,此方案适用于P2P对等点在任何网络点(说得可能比较绝对吧,大家有什么不同意见记得提出来哦,纯属个人的偏见)

总结:

立方打洞)
样)
一样)

由于我开发的只是简单的即时通讯系统,可能很多复杂的情况我没有考虑进去,例如存在多个NAT的嵌套,NAPTIP地址端口号转换没有考虑进去,路由器中的session的生命周期的不确定(有时候是几分钟,有时候几个小时不定),所以需要定期地进行穿透等等等等。

关于使用UDP(TCP)跨局域网,NAT穿透的心得的更多相关文章

  1. 使用TCP协议的NAT穿透技术

    一直以来,说起NAT穿透,很多人都会被告知使用UDP打孔这个技术,基本上没有人会告诉你如何使用TCP协议去穿透(甚至有的人会直接告诉你TCP协议是无法实现穿透的).但是,众所周知的是,UDP是一个无连 ...

  2. 使用TCP协议的NAT穿透技术(转)

    其实很早我就已经实现了使用TCP协议穿透NAT了,但是苦于一直没有时间,所以没有写出来,现在终于放假有一点空闲,于是写出来共享之. 一直以来,说起NAT穿透,很多人都会被告知使用UDP打孔这个技术,基 ...

  3. 使用TCP协议的NAT穿透技术 (转载)

    其实很早我就已经实现了使用TCP协议穿透NAT了,但是苦于一直没有时间,所以没有写出来,现在终于放假有一点空闲,于是写出来共享之. 一直以来,说起NAT穿透,很多人都会被告知使用UDP打孔这个技术,基 ...

  4. 网络协议之NAT穿透

    NAT IPv4地址只有32位,最多只能提供大致42.9亿个唯一IP地址,当设备越来越多时,IP地址变得越来越稀缺,不能为每个设备都分配一个IP地址.于是,作为NAT规范就出现了.NAT(Networ ...

  5. NAT穿透(UDP打洞)

    1.NAT(Network Address Translator)介绍 NAT有两大类,基本NAT和NAPT. 1.1.基本NAT 静态NAT:一个公网IP对应一个内部IP,一对一转换 动态NAT:N ...

  6. [转]UDP/TCP穿越NAT的P2P通信方法研究(UDP/TCP打洞 Hole Punching)

     [转]UDP/TCP穿越NAT的P2P通信方法研究(UDP/TCP打洞 Hole Punching) http://www.360doc.com/content/12/0428/17/6187784 ...

  7. [p2p]UDP用打洞技术穿透NAT的原理与实现

    首先先介绍一些基本概念:            NAT(Network Address             Translators),网络地址转换:网络地址转换是在IP地址日益缺乏的情况下产生的, ...

  8. udp之nat穿透的困惑

    nat穿透实现:[A]内网地址[内A]192.168.1.176:25789通过stun服务器查询映射到的外网地址为外网地址[外A]212.10.55.124:26559UDPsocketA绑定到[内 ...

  9. node.js UDP NAT 穿透实现

    源码:https://github.com/zhongchengyi/node-udp-trunnel-demo 1.原理 A登录Server, NAT A 分配端口11000,Server得到A的地 ...

随机推荐

  1. hbase0.95.2部署

    hbase0.95.2部署 下载安装包 hbase-0.95.2-cdh5.0.0-beta-1.tar.gz hbase需对应hadoop版本 解压 tar zxvf hbase-0.95.2-cd ...

  2. 如何在 .Net Framework 4.0 项目上使用 OData?

    最新的 Microsoft ASP.NET Web API 2.1 OData 5.1.0 已只能在 .Net Framework 4.5 的安装了,如果要在 VS2010的 .Net Framewo ...

  3. pygame系列_原创百度随心听音乐播放器_完整版

    程序名:PyMusic 解释:pygame+music 之前发布了自己写的小程序:百度随心听音乐播放器的一些效果图 你可以去到这里再次看看效果: pygame系列_百度随心听_完美的UI设计 这个程序 ...

  4. XmlElement 类

    构造函数   名称 说明 XmlElement(String, String, String, XmlDocument) 此 API 支持 产品 基础结构,不能在代码中直接使用. 初始化 XmlEle ...

  5. Spark - RDD(弹性分布式数据集)

    org.apache.spark.rddRDDabstract class RDD[T] extends Serializable with Logging A Resilient Distribut ...

  6. log4net配置文件设置

    windows服务执行cmd命令 最长公共子字符串 log4net配置文件设置 2011-11-16 13:15:41|  分类: Notes |  标签: |字号大中小 订阅     log4net ...

  7. Symantec Liveupdate Administrator的搭建

      1. My Symantec Products 选择需要更新的产品 2. Source Servers 选择ftp, 下载比较稳定 3. Distribute Center 类似于WSUS中的ap ...

  8. PHP == 和 ===

    == 只判断两边的值是否相等,例如: 5555 == "5555" ,为真 === 判断两边的值和类型是否相当,5555 === "5555"  False,因 ...

  9. SQL Server访问MySql

    使用环境:操作系统:window7数据库:SQL Server2005.MySql5.01.在安装了SQL Server的服务器上安装MySql的ODBC驱动:下载链接:http://dev.mysq ...

  10. 清橙 A1206 小Z的袜子(莫队算法)

    A1206. 小Z的袜子 时间限制:1.0s   内存限制:512.0MB   总提交次数:1357   AC次数:406   平均分:46.75   将本题分享到:        查看未格式化的试题 ...