Nat穿越方法以及服务器的制造方法

文档序号:7988900阅读:289来源:国知局
Nat穿越方法以及服务器的制造方法
【专利摘要】本发明公开了一种NAT穿越方法以及服务器,属于网络【技术领域】。所述方法包括:接收客户端向预定地址发送的第一请求信息;根据所述第一请求信息创建与所述客户端之间的第一连接;接收所述客户端通过第一连接发送的第二请求信息;根据所述第二请求信息创建与所述通信对端之间的第二连接;根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。
【专利说明】NAT穿越方法以及服务器
【技术领域】
[0001]本发明涉及网络【技术领域】,特别涉及一种NAT穿越方法以及服务器。
【背景技术】
[0002]NAT (NetworkAddress Translation,网络地址转换)是广域网中为解决公网IP(Internet Protocol,互联网协议地址)地址紧缺所采用的主要技术之一。在使用NAT设备的广域网中,公网中的客户端不能主动向私网中的客户端发起通信,所以如何实现NAT穿越已经成为互联网通信领域的技术人员现阶段重要的研究课题之一。
[0003]现有的一种NAT穿越方法,包括:客户端向STUN (Simple Traversal ofUDPoverNATs, NAT的UDP简单穿越)服务器发送NAT设备类型检测请求,从而获取客户端对应的NAT设备类型信息;客户端向通信对端发起会话,以便向通信对端发送客户端对应的NAT设备类型信息,并同时获得通信对端对应的NAT设备类型信息;客户端和通信对端根据双方的NAT设备类型采用相应的NAT设备穿越方法;客户端和通信对端进行数据传输。
[0004]在实现本发明的过程中,发明人发现现有技术至少存在如下问题:
[0005]在客户端执行NAT设备穿越之前,客户端需要向STUN服务器发送NAT设备类型检测请求,从而STUN服务器在检测到客户端的NAT设备类型后反馈给客户端。所以这就导致当出现新的NAT设备类型时,STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT的穿越,所以现有方案适应性不高。

【发明内容】

[0006]为了解决现有的NAT穿越方法适应性不高的问题,本发明实施例提供了一种NAT穿越方法和服务器。所述技术方案如下:
[0007]根据本发明的一个方面,提供了一种NAT穿越方法,所述方法包括:
[0008]接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息;
[0009]根据所述第一请求信息创建与所述客户端之间的所述第一连接;
[0010]接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0011]根据所述第二请求信息创建与所述通信对端之间的第二连接;
[0012]根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
[0013]优选地,所述第二请求信息中的协议标识为用户数据包协议UDP标识,所述根据所述第二请求信息创建与所述通信对端之间的第二连接,包括:
[0014]在本地开设与所述通信对端对应的UDP端口,以便与所述通信对端建立UDP通道;
[0015]建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端口 ;
[0016]向所述客户端发送通道建立成功响应。
[0017]优选地,所述根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包,包括:
[0018]接收所述客户端通过第一连接发送的第一类型数据包;
[0019]将所述第一类型数据包重新封装为UDP数据包;
[0020]根据所述对应关系,选择对应的第二连接将所述UDP数据包转发给所述通信对端;
[0021]和/ 或,
[0022]接收所述通信对端通过第二连接发送的UDP数据包,所述UDP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0023]将所述UDP数据包重新封装为第一类型数据包;
[0024]根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0025]优选地,所述第二请求信息中的协议标识为传输控制协议TCP标识,所述根据所述第二请求信息创建与所述通信对端之间的第二连接,包括:
[0026]根据所述第二请求信息中通信对端的IP地址和端口执行与所述通信对端的三次握手过程,从而建立与所述通信对端的TCP通道;
[0027]建立所述客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系;
[0028]向所述客户端发送通道建立成功响应。
[0029]优选地,所述根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包,包括:
[0030]接收所述客户端通过第一连接发送的第一类型数据包;
[0031 ] 将所述第一类型数据包重新封装为TCP数据包;
[0032]根据所述对应关系,选择对应的第二连接将所述TCP数据包转发给所述通信对端;
[0033]和/ 或,
[0034]接收所述通信对端通过第二连接发送的TCP数据包,所述TCP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0035]将所述TCP数据包重新封装为第一类型数据包;
[0036]根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0037]根据本发明的另一方面,提供了一种服务器,所述服务器包括:
[0038]第一接收模块,用于接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息;
[0039]第一创建模块,用于根据所述第一请求信息创建与所述客户端之间的所述第一连接;
[0040]第二接收模块,用于接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0041]第二创建模块,用于根据所述第二请求信息创建与所述通信对端之间的第二连接;
[0042]数据传输模块,用于根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
[0043]优选地,所述第二请求信息中的协议标识为用户数据包协议UDP标识,所述第二创建模块,包括:
[0044]第一建立单元,用于在本地开设与所述通信对端对应的UDP端口,以便与所述通信对端建立UDP通道;
[0045]第二建立单元,用于建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端口 ;
[0046]第一发送单元,用于向所述客户端发送通道建立成功响应。
[0047]优选地,所述数据传输模块,包括:
[0048]第一接收单元,用于接收所述客户端通过第一连接发送的第一类型数据包;
[0049]第一封装单元,用于将所述第一类型数据包重新封装为UDP数据包;
[0050]第一转发单元,用于根据所述对应关系,选择对应的第二连接将所述UDP数据包转发给所述通信对端;
[0051]第二接收单元,用于接收所述通信对端通过第二连接发送的UDP数据包,所述UDP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0052]第二封装单元,用于将所述UDP数据包重新封装为第一类型数据包;
[0053]第二转发单元,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0054]优选地,所述第二请求信息中的协议标识为传输控制协议TCP标识,所述第二创建模块,包括:
[0055]第三建立单元,用于根据所述第二请求信息中通信对端的IP地址和端口执行与所述通信对端的三次握手过程,从而建立与所述通信对端的TCP通道;
[0056]第四建立单元,用于建立所述客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系;
[0057]第二发送单元,用于向所述客户端发送通道建立成功响应。
[0058]优选地,所述数据传输模块,包括:
[0059]第三接收单元,用于接收所述客户端通过第一连接发送的第一类型数据包;
[0060]第三封装单元,用于将所述第一类型数据包重新封装为TCP数据包;
[0061]第三转发单元,用于根据所述对应关系,选择对应的第二连接将所述TCP数据包转发给所述通信对端;
[0062]第四接收单元,用于接收所述通信对端通过第二连接发送的TCP数据包,所述TCP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0063]第四封装单元,用于将所述TCP数据包重新封装为第一类型数据包;
[0064]第四转发单元,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0065]本发明实施例提供的技术方案带来的有益效果是:
[0066]通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行第一连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。
【专利附图】

【附图说明】
[0067]为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
[0068]图1是本发明一个实施例提供的NAT穿越方法的方法流程图;
[0069]图2是本发明另一实施例提供的NAT穿越方法的方法流程图;
[0070]图3是本发明再一实施例提供的NAT穿越方法的方法流程图;
[0071]图4是本发明一个实施例提供的服务器的结构方框图;
[0072]图5是本发明另一实施例提供的服务器的结构方框图;
[0073]图6是本发明另一实施例提供的服务器的结构方框图;
[0074]图7是本发明再一实施例提供的服务器的结构方框图;
[0075]图8是本发明再一实施例提供的服务器的结构方框图。
【具体实施方式】
[0076]为使本发明的目的、技术方案和优点更加清楚,下面将结合附图对本发明实施方式作进一步地详细描述。
[0077]请参考图1,其示出了本发明一个实施例所提供的NAT穿越方法的方法流程图。本实施例主要以该NAT穿越方法应用于位于公网中的TLS服务器中来举例说明。该NAT穿越方法包括:
[0078]步骤101,TLS服务器接收客户端向预定地址发送的第一请求信息;
[0079]由于公网中的通信对端不能主动发起与私网中的客户端之间的通信,也即不能主动发起与NAT设备后的客户端之间的通信,所以为了避免这种情况,在通信对端与客户端进行通信之前,NAT设备后的客户端可以先与TLS (Transport Layer Security,安全传输协议)服务器建立第一连接,所以客户端可以向预定地址发送一个第一请求信息,相应的,TLS服务器可以接收客户端发送的第一请求信息,第一请求信息用于建立第一连接的握手信息。
[0080]步骤102,TLS服务器根据第一请求信息创建与客户端之间的第一连接;
[0081]TLS服务器接收到客户端发送的第一请求信息之后,TLS服务器可以根据第一请求信息创建与客户端之间的第一连接。
[0082]步骤103,TLS服务器接收客户端通过第一连接发送的第二请求信息,第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0083]在TLS服务器创建了与客户端之间的第一连接后,客户端可以通过第一连接向预定地址发送第二请求信息,相应的,TLS服务器可以接收客户端发送的第二请求信息,第二请求信息包括协议标识、通信对端的IP地址和端口。
[0084]步骤104,根据第二请求信息创建与通信对端之间的第二连接;
[0085]由于第二请求信息中包括通信对端的IP地址和端口,所以当TLS服务器接收到客户端发送的第二请求信息时,TLS服务器可以根据第二请求信息创建与通信对端之间的第二连接。
[0086]步骤105,根据第一连接和第二连接在客户端与通信对端之间传递数据包。
[0087]当TLS服务器创建了与通信对端的第二连接之后,TLS服务器已经分别通过第一连接与客户端连接,通过第二连接与通信对端连接,所以此时TLS服务器可以根据第一连接和第二连接在客户端与通信对端之间传递数据包。
[0088]综上所述,本实施例提供的NAT穿越方法,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0089]请参考图2,其示出了本发明另一实施例所提供的NAT穿越方法的方法流程图。本实施例主要以该NAT穿越方法应用于位于公网中的TLS服务器中,并且客户端需要发送的数据包是UDP (User Datagram Protocol,用户数据包协议)数据包来举例说明。该NAT穿越方法包括:
[0090]步骤201,客户端向预定地址发送第一请求信息;
[0091]由于公网中的通信对端不能主动发起与私网中的客户端之间的通信,也即不能主动发起与NAT设备后的客户端之间的通信,所以为了避免这种情况,在通信对端与客户端进行通信之前,NAT设备后的客户端需要先与TLS服务器建立TLS连接,所以客户端可以向TLS服务器的预定端口发送第一请求信息,第一请求信息可以包括用于建立第一连接的握手信息,客户端与TLS服务器建立第一连接时需要的握手信息可以包括TLS协议的版本号、客户端支持的非对称算法、对称算法、哈希算法和其他信息,本实施例对此并不做限定。
[0092]具体地,在客户端需要与TLS服务器建立连接时,客户端可以向TLS服务器中的TCP信令端口发送第一请求信息。比如,TLS服务器的IP地址为10.10.40.70,TLS服务器中的TCP信令端口的端口号为888,则客户端可以向IP地址和端口为10.10.40.70:888的预定地址发送第一请求信息。
[0093]步骤202,TLS服务器接收客户端向预定地址发送的第一请求信息;
[0094]在客户端向TLS服务器发送第一请求信息之后,TLS服务器可以相应的接收客户端发送的第一请求信息。
[0095]步骤203,TLS服务器根据第一请求信息创建与客户端之间的第一连接;
[0096]TLS服务器在接收到客户端发送的第一请求信息后,TLS服务器可以根据第一请求信息中的TLS协议的版本号、客户端支持的非对称算法、对称算法和哈希算法与对应的客户端进行算法协商、证书认证以及密钥协商,当协商通过后,TLS服务器建立与客户端之间的第一连接,也即建立TLS服务器与客户端之间的TLS连接。
[0097]步骤204,客户端通过第一连接发送第二请求信息;
[0098]为了使得客户端能够通过TLS服务器与对应的UDP服务器进行通信,在TLS服务器建立与客户端之间的第一连接之后,客户端可以通过第一连接向预定地址发送请求建立UDP通道的第二请求信息,第二请求信息包括协议标识、通信对端的IP地址和端口,预定地址包括TLS服务器的IP地址和TLS服务器中的TCP端口的端口号。
[0099]在具体的通信系统中,当客户端需要向通信对端发送的数据包是UDP数据包时,协议标识可以是UDP标识,此时通信对端为UDP服务器;当客户端需要向通信对端发送的数据包是TCP (Transmission Control Protocol,传输控制协议)数据包时,协议标识可以是TCP标识,此时通信对端为TCP服务器,本实施例以客户端需要向通信对端发送的数据包是UDP数据包,也即第二请求信息中的协议标识是UDP标识为例。
[0100]tt ia,客户端想要发送一个UDP数据包至IP地址和端口为192.168.1.128:6000的UDP服务器,则客户端可以通过第一连接向TLS服务器发送包括UDP标识和192.168.1.128:6000 的第二请求信息。
[0101]然而,由于现有的通信系统中,为了解决公网IP地址紧缺的问题,同时也提出了使用IPv6 (Internet Protocol Version6,第6版互联网协议)的解决方案,所以为了使得TLS服务器能够知道UDP服务器使用的IP协议,从而与通信对端建立通信通道,第二请求信息中还可以包括类别标识也即IPv4或IPv6。需要说明的是,当某一个区域内全都使用IPv4或IPv6时,此时,第二请求信息中可以不包括IPv4或IPv6,本实施例对此并不做限定。
[0102]步骤205,TLS服务器接收客户端通过第一连接发送的第二请求信息;
[0103]客户端通过第一连接发送第二请求信息之后,TLS服务器可以相应的接收到客户端发送的第二请求信息。比如,客户端发送的第二请求信息包括UDP标识和通信对端的192.168.1.128:6000,则TLS服务器可以相应的接收到包括UDP标识和通信对端的IP地址和端口 192.168.1.128:6000的第二请求信息。
[0104]步骤206,TLS服务器在本地开设与通信对端对应的UDP端口,以便与通信对端建立UDP通道;
[0105]由于UDP是一种面向无连接的传输层协议,所以在TLS服务器接收到客户端发送的第二请求信息之后,TLS服务器可以根据UDP服务器的IP地址和端口为该UDP服务器开设UDP端口,以便TLS服务器使用开设的UDP端口与对应的UDP服务器建立UDP通道。
[0106]步骤207,TLS服务器建立客户端的IP地址和端口与通信对端的IP地址和端口之间的对应关系;
[0107]TLS服务器在本地开设与UDP服务器对应的UDP端口之后,说明此时TLS服务器可以使用该UDP端口与UDP服务器进行通信,所以TLS服务器可以建立客户端的IP地址和端口与m)P服务器的IP地址和端口之间的对应关系,从而使得TLS服务器在接收到某一客户端发送的数据包之后能够转发至对应的UDP服务器,客户端的IP地址和端口是通过第一请求信息获取的IP地址和端口,也即是客户端在请求与TLS服务器建立TLS连接时,TLS服务器通过客户端发送的数据包而获取的,本实施例对此不再赘述。
[0108]比如,在TLS服务器开设与UDP服务器对应的UDP端口之后,TLS服务器将建立客户端的10.10.40.170:2000以及该客户端想要通信的UDP服务器的192.168.1.128:6000的对应关系,从而使得当TLS服务器接收到来自10.10.40.170:2000的数据包时,TLS服务器知道该数据包是要发送至192.168.1.128:6000对应的UDP服务器的。
[0109]步骤208,TLS服务器向客户端发送通道建立成功响应;
[0110]在TLS服务器在本地开设与UDP服务器对应的UDP端口之后,说明此时TLS服务器与UDP服务器的第二连接已经创建成功,TLS服务器可以开始使用该UDP端口与UDP服务器进行通信,所以为了告知客户端此时TLS服务器可以将客户端发送数据包转发至对应的UDP服务器,TLS服务器可以向客户端发送UDP通道建立成功响应,相应的,客户端可以接收TLS服务器发送的UDP通道建立成功响应。比如,在具体实现时,TLS服务器可以向客户端发送一个二进制数据包,并使用该二进制数据包携带对应于第二请求信息的确认信息。
[0111]需要说明的是,步骤207和步骤208可以同时执行,也可以分先后顺序执行,本实施例对此并不做限定。
[0112]步骤209,TLS服务器接收客户端通过第一连接发送的第一类型数据包;
[0113]在客户端接收到TLS服务器发送的通道建立成功响应之后,客户端可以通过第一连接向TLS服务器发送第一类型数据包。
[0114]具体地,由于客户端与TLS服务器之间使用的是TLS连接,所以客户端向TLS服务器发送的第一类型数据包是TLS数据包。并且由于TLS服务器中的TCP信令端口可以同时中继信令和数据包,所以在客户端需要通过第一连接发送TLS数据包至TLS服务器时,客户端也可以通过第一连接发送TLS数据包。
[0115]步骤210,TLS服务器将第一类型数据包重新封装为UDP数据包;
[0116]在TLS服务器接收到客户端通过第一连接发送的第一类型数据包之后,TLS服务器可以将第一类型数据包重新封装为UDP数据包。具体地,由于TLS服务器需要将接收到的客户端发送的TLS数据包转发至对应的通信对端也即对应的UDP服务器,所以TLS在接收到客户端发送的TLS数据包之后,可以将TLS数据包重新封装为UDP数据包,具体封包方法为现有技术,在此不再赘述。
[0117]步骤211,TLS服务器根据对应关系,选择对应的第二连接将UDP数据包转发给通信对端;
[0118]在TLS服务器将客户端发送的TLS数据包重新封装为UDP数据包之后,TLS服务器可以根据已经建立的客户端的IP地址和端口与通信对端的IP地址和端口的对应关系,选择对应的第二连接将m)P数据包转发给对应的通信对端。
[0119]比如,TLS服务器接收到的TLS数据包是10.10.40.170:2000发送的数据包,则在TLS将数据包重新封装为UDP数据包之后,TLS服务器可以查询与10.10.40.170:2000对应的UDP服务器,并且根据步骤207可以知道,TLS服务器创建的与10.10.40.170:2000对应的UDP服务器的IP地址和端口为192.168.1.128:6000,所以TLS服务器可以把已经重新封装的UDP数据包转发至192.168.1.128:6000对应的UDP服务器。
[0120]步骤212,TLS服务器接收通信对端通过第二连接发送的UDP数据包;
[0121]若UDP服务器需要向客户端发送数据包,则UDP服务器可以通过第二连接发送UDP数据包至TLS服务器,UDP数据包是通信对端在接收到客户端发送的数据包之后发送的数据包。
[0122]具体地,由于在UDP服务器接收到UDP数据包之前,通信对端并不知道该客户端的存在,所以UDP服务器向TLS服务器发送的UDP数据包必须是UDP服务器在接收到客户端发送的数据包之后发送的数据包。
[0123]步骤213,TLS服务器将UDP数据包重新封装为第一类型数据包;
[0124]在TLS服务器接收到UDP服务器发送的数据包之后,TLS服务器需要通过第一连接也即TLS连接将UDP数据包转发至对应的客户端,所以TLS服务器在接收到UDP数据包之后,TLS可以把UDP数据包重新封装为第一类型数据包也即TLS数据包,在此不再赘述。
[0125]步骤214,TLS服务器根据对应关系,选择对应的第一连接和第二连接将第一类型数据包转发给对应的客户端。
[0126]在TLS服务器将UDP服务器发送的UDP数据包重新封装为TLS数据包之后,TLS服务器可以根据已经建立的客户端的IP地址和端口与UDP服务器的IP地址和端口的对应关系,选择对应的第一连接,并且通过第一连接将TLS数据包转发给客户端。
[0127]需要补充说明的一点是,步骤209至步骤211与步骤212至步骤214,可以同时存在于一个通信系统中,也可以只存在步骤209至步骤211或者步骤212至步骤214,本实施例对此并不做限定。
[0128]需要补充说明的另一点是,在TLS服务器与通信对端建立了 UDP通道之后,TLS服务器会为每个UDP通道分配一个存活时间,当该UDP通道中在存活时间内没有数据包或刷新通过时,TLS服务器将关闭该UDP通道,所以为了避免客户端在长时间没有向UDP服务器发送数据包,但是之后当再次需要使用第二连接向UDP服务器发送数据包时,TLS服务器将UDP通道关闭的问题,客户端可以在TLS服务器为UDP通道分配的存活时间快到期时,向TLS服务器发送一个通道刷新请求,TLS服务器可以通过该通道刷新请求来维护UDP通道。在实际实现时,可以在通道刷新请求中携带一个预定时间,从而TLS服务器在接收到通道刷新请求时,为UDP通道分配一个时长为预定时间的存活时间;然而当客户端不再需要发送数据包至UDP服务器时,为了释放原本就紧缺的UDP端口资源,客户端将向TLS服务器发送一个携带预定时间为O的通道刷新请求,从而在TLS服务器接收到该通道刷新请求时,关闭该UDP通道从而释放UDP端口资源;[0129]需要补充说明的再一点是,由于TLS连接是可以复用的连接,所以在客户端与第一通信对端通信完成后,客户端可以向TLS服务器发送一个通道刷新请求,该通道刷新请求中携带的预定时间的时长为0,在TLS服务器接收到通道刷新请求后TLS服务器可以关闭与UDP服务器之间的第二连接也即UDP通道,而保持第一连接连通。之后客户端仍然可以继续通过第一连接发送与第二通信对端对应的第二请求信息,从而TLS服务器建立与第二通信对端之间的UDP通道;
[0130]需要补充说明的再一点是,客户端还可以同时通过第一连接使得TLS服务器与多个通信对端建立UDP通道,也即此时与第一连接对应的第二连接有多个,本实施例对此并不做限定。
[0131]综上所述,本实施例提供的NAT穿越方法,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0132]请参考图3,其示出了本发明实施例再一实施例提供的NAT穿越方法的方法流程图。本实施例主要以该NAT穿越方法应用于位于公网中的TLS服务器中,并且客户端需要发送的数据包是TCP数据包来举例说明。该NAT穿越方法包括:
[0133]步骤301,客户端向预定地址发送第一请求信息;
[0134]由于公网中的通信对端不能主动发起与私网中的客户端之间的通信,也即不能主动发起与NAT设备后的客户端之间的通信,所以为了避免这种情况,在通信对端与客户端进行通信之前,NAT设备后的客户端需要先与TLS服务器建立TLS连接,所以客户端可以向TLS服务器的预定端口发送第一请求信息,第一请求信息可以包括用于建立第一连接的握手信息,客户端与TLS服务器建立第一连接时需要的握手信息可以包括TLS协议的版本号、客户端支持的非对称算法、对称算法、哈希算法和其他信息,本实施例对此并不做限定。
[0135]具体地,在客户端需要与TLS服务器建立连接时,客户端可以向TLS服务器中的TCP信令端口发送第一请求信息。
[0136]步骤302,TLS服务器接收客户端向预定地址发送的第一请求信息;
[0137]在客户端向TLS服务器发送第一请求信息之后,TLS服务器可以相应的接收客户端发送的第一请求信息。
[0138]步骤303,TLS服务器根据第一请求信息创建与客户端之间的第一连接;[0139]TLS服务器在接收到客户端发送的第一请求信息后,TLS服务器可以根据第一请求信息中的TLS协议的版本号、客户端支持的非对称算法、对称算法和哈希算法与对应的客户端进行算法协商、证书认证以及密钥协商,当协商通过后,TLS服务器建立与客户端之间的第一连接,也即建立TLS服务器与客户端之间的TLS连接。
[0140]步骤304,客户端通过第一连接发送第二请求信息;
[0141]为了使得客户端能够通过TLS服务器与对应的UDP服务器进行通信,在TLS服务器建立与客户端之间的第一连接之后,客户端可以通过第一连接向预定地址发送第二请求信息,第二请求信息包括协议标识、通信对端的IP地址和端口,预定地址包括TLS服务器的IP地址和TLS服务器中的TCP端口的端口号。
[0142]在具体的通信系统中,当客户端需要向通信对端发送的数据包是UDP数据包时,协议标识可以是UDP标识,此时通信对端为UDP服务器;当客户端需要向通信对端发送的数据包是TCP数据包时,协议标识可以是TCP标识,此时通信对端为TCP服务器,本实施例以客户端需要向通信对端发送的数据包是TCP数据包,也即第二请求信息中的协议标识是TCP标识为例。
[0143]然而,由于现有的通信系统中,为了解决公网IP地址紧缺的问题,同时也提出了使用IPv6 (Internet Protocol Version6,第6版互联网协议)的解决方案,所以为了使得TLS服务器能够知道TCP服务器使用的IP协议,从而与通信对端建立通信通道,第二请求信息中还可以包括类别标识也即IPv4或IPv6。需要说明的是,当某一个区域内全都使用IPv4或IPv6时,此时,第二请求信息中可以不包括IPv4或IPv6,本实施例对此并不做限定。
[0144]步骤305,TLS服务器接收客户端通过第一连接发送的第二请求信息;
[0145]客户端通过第一连接发送第二请求信息之后,TLS服务器可以相应的接收到客户端发送的第二请求信息。
[0146]步骤306,TLS服务器根据第二请求信息中通信对端的IP地址和端口执行与通信对端的三次握手过程,从而建立与通信对端的TCP通道;
[0147]在TLS服务器接收到客户端发送的第二请求信息之后,TLS服务器可以根据第二请求信息中TCP服务器的IP地址和端口执行与TCP服务器的三次握手,从而建立与TCP服务器的TCP通道。
[0148]步骤307,TLS服务器建立客户端的IP地址和端口与通信对端的IP地址和端口之间的对应关系;
[0149]在TLS服务器创建与TCP服务器之间的TCP通道之后,TLS服务器可以通过TCP通道与TCP服务器进行通信,所以此时TLS服务器可以建立客户端的IP地址和端口与TCP服务器的IP地址和端口之间的对应关系,从而使得TLS服务器在接收到某一客户端发送的数据包之后能够转发至对应的TCP服务器,客户端的IP地址和端口是通过第一请求信息获取的IP地址和端口,也即是客户端在请求与TLS服务器建立TLS连接时,TLS服务器通过客户端发送的数据包而获取的,本实施例对此不再赘述。
[0150]比如,在TLS服务器创建与TCP服务器之间的TCP通道之后,TLS服务器将建立客户端的10.10.40.170:2000以及该客户端想要通信的TCP服务器的192.168.1.128:6000的对应关系,从而使得当TLS服务器接收到来自10.10.40.170:2000的数据包时,TLS服务器知道该数据包是要发送至192.168.1.128:6000对应的TCP服务器的。[0151]步骤308,TLS服务器向客户端发送通道建立成功响应;
[0152]在TLS服务器创建与TCP服务器之间的TCP通道之后,说明此时TLS服务器与TCP服务器的第二连接创建成功,TLS服务器可以开始通过TCP通道与TCP服务器进行通信,所以为了告知客户端此时TLS服务器可以将客户端发送数据包转发至对应的TCP服务器,TLS服务器可以向客户端发送通道建立成功响应,相应的,客户端可以接收TLS服务器发送的通道建立成功响应。比如,在具体实现时,TLS服务器可以向客户端发送一个二进制数据包,并使用该二进制数据包携带对应于第二请求信息的确认信息。
[0153]需要说明的是,步骤207和步骤208可以同时执行,也可以分先后顺序执行,本实施例对此并不做限定。
[0154]步骤309,TLS服务器接收客户端通过第一连接发送的第一类型数据包;
[0155]在客户端接收到TLS服务器发送的通道建立成功响应之后,客户端可以通过第一连接向TLS服务器发送第一类型数据包。
[0156]步骤310,TLS服务器将第一类型数据包重新封装为TCP数据包;
[0157]在TLS服务器接收到客户端通过第一连接发送的第一类型数据包之后,TLS服务器可以将第一类型数据包重新封装为TCP数据包。具体地,由于TLS服务器需要将接收到的客户端发送的TLS数据包转发至对应的通信对端也即对应的TCP服务器,所以TLS在接收到客户端发送的TLS数据包之后,可以将TLS数据包重新封装为TCP数据包,具体封包方法为现有技术,在此不再赘述。
[0158]步骤311,TLS服务器根据对应关系,选择对应的第二连接将TCP数据包转发给通信对端;
[0159]在TLS服务器将客户端发送的TLS数据包重新封装为TCP数据包之后,TLS服务器可以根据已经建立的客户端的IP地址和端口与通信对端的IP地址和端口的对应关系,选择对应的第二连接将TCP数据包转发给对应的通信对端。
[0160]步骤312,TLS服务器接收通信对端通过第二连接发送的TCP数据包,TCP数据包是通信对端在接收到客户端发送的数据包之后发送的数据包;
[0161]若TCP服务器需要向客户端发送数据包,则TCP服务器可以通过第二连接发送TCP数据包至TLS服务器,TCP数据包是通信对端在接收到客户端发送的数据包之后发送的数据包。
[0162]具体地,由于在TCP服务器接收到TCP数据包之前,通信对端并不知道该客户端的存在,所以TCP服务器向TLS服务器发送的TCP数据包必须是TCP服务器在接收到客户端发送的数据包之后发送的数据包。
[0163]步骤313,TLS服务器将TCP数据包重新封装为第一类型数据包;
[0164]在TLS服务器接收到TCP服务器发送的数据包之后,TLS服务器需要通过第一连接也即TLS连接将TCP数据包转发至对应的客户端,所以TLS服务器在接收到TCP数据包之后,TLS可以把TCP数据包重新封装为第一类型数据包也即TLS数据包,在此不再赘述。
[0165]步骤314,TLS服务器根据对应关系,选择对应的第一连接将第一类型数据包转发给客户端。
[0166]在TLS服务器将TCP服务器发送的TCP数据包重新封装为TLS数据包之后,TLS服务器可以根据已经建立的客户端的IP地址和端口与TCP服务器的IP地址和端口的对应关系,选择对应的第一连接,并且通过第一连接将TLS数据包转发给客户端。
[0167]需要补充说明的一点是,步骤309至步骤311与步骤312至步骤314,可以同时存在于一个通信系统中,也可以只存在步骤309至步骤311或者步骤312至步骤314,本实施例对此并不做限定;
[0168]需要补充说明的另一点是,在TLS服务器与通信对端建立了 TCP通道之后,TLS服务器会为每个TCP通道分配一个通常为20分钟的存活时间,当该TCP通道中在存活时间内没有数据包或刷新通过时,TLS服务器将降低该TCP通道的优先级直至关闭该TCP通道,所以为了避免客户端在长时间内没有向TCP服务器发送数据包,但是之后当再次需要使用第二连接向TCP服务器发送数据包时,TLS将TCP通道的优先级降低甚至关闭的问题,客户端可以在TLS为TCP分配的存活时间快到期时,向TLS服务器发送一个通道刷新请求,TLS服务器可以通过该通道刷新请求来维护TCP通道。在实际实现时,可以在通道刷新请求中携带一个预定时间,从而TLS服务器在接收到通道刷新请求时,为TCP通道分配一个时长为预定时间的存活时间;然而当客户端不再需要发送数据包至TCP服务器时,客户端将向TLS服务器发送一个携带预定时间为O的通道刷新请求,从而在TLS服务器接收到该通道刷新请求时,释放该TCP通道;
[0169]需要补充说明的再一点是,由于TLS连接是可以复用的连接,所以在客户端与第一通信对端通信完成后,客户端可以向TLS服务器发送一个通道刷新请求,该通道刷新请求中携带的预定时间的时长为0,在TLS服务器接收到该通道刷新请求之后TLS服务器可以关闭与TCP服务器之间的第二连接也即TCP通道,而保持第一连接连通。之后客户端仍然可以继续通过第一连接发送与第二通信对端对应的第二请求信息,从而TLS服务器建立与第二通信对端之间的TCP通道;
[0170]需要补充说明的再一点是,客户端还可以同时通过第一连接使得TLS服务器与多个通信对端建立TCP通道,也即此时与第一连接对应的第二连接有多个,本实施例对此并不做限定。
[0171]综上所述,本实施例提供的NAT穿越方法,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0172]请参考图4,其示出了本发明一个实施例提供的服务器的结构方框图,该服务器包括:第一接收模块410、第一创建模块420、第二接收模块430、第二创建模块440和数据传输模块450。
[0173]第一接收模块410,用于接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息;
[0174]第一创建模块420,用于根据所述第一请求信息创建与所述客户端之间的所述第一连接;
[0175]第二接收模块430,用于接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0176]第二创建模块440,用于根据所述第二请求信息创建与所述通信对端之间的第二连接;
[0177]数据传输模块450,用于根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
[0178]综上所述,本实施例提供的服务器,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0179]请参考图4,其示出了本发明另一实施例提供的服务器的结构方框图。该服务器包括:第一接收模块410、第一创建模块420、第二接收模块430、第二创建模块440和数据传输模块450。
[0180]第一接收模块410,用于接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息;
[0181]第一创建模块420,用于根据所述第一请求信息创建与所述客户端之间的所述第一连接;
[0182]第二接收模块430,用于接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0183]第二创建模块440,用于根据所述第二请求信息创建与所述通信对端之间的第二连接;
[0184]数据传输模块450,用于根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
[0185]请参考图5,在本实施例中,所述第二创建模块440包括第一建立单元441、第二建立单元442和第一发送单元443 ;
[0186]第一建立单元441,用于在本地开设与所述通信对端对应的UDP端口,以便与所述通信对端建立UDP通道;
[0187]第二建立单元442,用于建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端口 ;
[0188]第一发送单元443,用于向所述客户端发送通道建立成功响应。
[0189]请参考图6,在本实施例中,所述数据传输模块450包括第一接收单元451、第一封装单元452、第一转发单元453、第二接收单元454、第二封装单元455和第二转发单元456。
[0190]第一接收单元451,用于接收所述客户端通过第一连接发送的第一类型数据包;
[0191]第一封装单元452,用于将所述第一类型数据包重新封装为UDP数据包;
[0192]第一转发单元453,用于根据所述对应关系,选择对应的第二连接将所述UDP数据包转发给所述通信对端;
[0193]第二接收单元454,用于接收所述通信对端通过第二连接发送的UDP数据包,所述UDP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0194]第二封装单元455,用于将所述UDP数据包重新封装为第一类型数据包;
[0195]第二转发单元456,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0196]需要补充说明的是,本实施例提供的服务器可以是一个实体,也可以是设置在NAT设备中,本实施例对其具体实现形式并不做限定。
[0197]综上所述,本实施例提供的服务器,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0198]请参考图4,其示出了本发明再一实施例提供的服务器的结构方框图。该服务器包括:第一接收模块410、第一创建模块420、第二接收模块430、第二创建模块440和数据传输模块450。
[0199]第一接收模块410,用于接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息;
[0200]第一创建模块420,用于根据所述第一请求信息创建与所述客户端之间的所述第一连接;
[0201]第二接收模块430,用于接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ;
[0202]第二创建模块440,用于根据所述第二请求信息创建与所述通信对端之间的第二连接;
[0203]数据传输模块450,用于根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
[0204]请参考图7,在本实施例中,所述第二创建模块包括:第三建立单元444、第四建立单元445、第二发送单元446。
[0205]第三建立单元444,用于根据所述第二请求信息中通信对端的IP地址和端口执行与所述通信对端的三次握手过程,从而建立与所述通信对端的TCP通道;
[0206]第四建立单元445,用于建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端口 ;
[0207]第二发送单元446,用于向所述客户端发送通道建立成功响应。
[0208]请参考图8,在本实施例中,所述数据传输模块包括:第三接收单元457、第三封装单元458、第三转发单元459、第四接收单元460、第四封装单元461和第四转发单元462。
[0209]第三接收单元457,用于接收所述客户端通过第一连接发送的第一类型数据包;
[0210]第三封装单元458,用于将所述第一类型数据包重新封装为TCP数据包;
[0211]第三转发单元459,用于根据所述对应关系,选择对应的第二连接将所述TCP数据包转发给所述通信对端;
[0212]第四接收单元460,用于接收所述通信对端通过第二连接发送的TCP数据包,所述TCP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包;
[0213]第四封装单元461,用于将所述TCP数据包重新封装为第一类型数据包;
[0214]第四转发单元462,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
[0215]需要补充说明的是,本实施例提供的服务器可以是一个实体,也可以是设置在NAT设备中,本实施例对其具体实现形式并不做限定。
[0216]综上所述,本实施例提供的服务器,通过接收客户端向预定地址发送的第一请求信息和第二请求信息,并且根据第一请求信息创建与客户端之间的第一连接,根据第二请求信息创建与通信对端之间的第二连接,从而根据第一连接和第二连接在客户端和通信对端之间传递数据包。由于NAT设备后的客户端与服务器之间建立的第一连接是TLS连接,并且TLS连接对于NAT设备来说是可信任的连接,所以不论客户端在什么类型的NAT设备之后,客户端都能成功穿越NAT设备而与服务器进行连接,并且客户端通过发送第二请求信息至服务器使得服务器建立与通信对端之间的第二连接,从而服务器根据第一连接和第二连接在客户端和通信对端之间传递数据包,解决了现有技术中,当出现新的NAT设备类型时,由于STUN服务器无法检测NAT设备类型或者检测到的NAT设备类型可靠性不高时,客户端不能实现NAT穿越,从而导致的现有方案适应性不高的问题,达到了可以不用考虑NAT设备类型而可以实现穿越的效果。并且在本实施例中,通过使用一个预定地址来接收客户端发送的第一请求信息和第二请求信息,并且同时接收客户端向通信对端发送的数据包,达到了服务器可以只用一个端口即可为多个客户端服务从而提高地址资源利用率的效果。
[0217]需要说明的是:上述实施例提供的服务器在执行NAT穿越时,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将服务器的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的服务器与NAT穿越方法实施例属于同一构思,其具体实现过程详见方法实施例,这里不再赘述。
[0218]上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
[0219]本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
[0220]以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
【权利要求】
1.一种NAT穿越方法,其特征在于,所述方法包括: 接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息; 根据所述第一请求信息创建与所述客户端之间的所述第一连接; 接收所述客户端通过所述第一连 接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ; 根据所述第二请求信息创建与所述通信对端之间的第二连接; 根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
2.根据权利要求1所述的NAT穿越方法,其特征在于,所述第二请求信息中的协议标识为用户数据包协议UDP标识,所述根据所述第二请求信息创建与所述通信对端之间的第二连接,包括: 在本地开设与所述通信对端对应的UDP端口,以便与所述通信对端建立UDP通道; 建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端口 ; 向所述客户端发送通道建立成功响应。
3.根据权利要求2所述的NAT穿越方法,其特征在于,所述根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包,包括: 接收所述客户端通过第一连接发送的第一类型数据包; 将所述第一类型数据包重新封装为UDP数据包; 根据所述对应关系,选择对应的第二连接将所述UDP数据包转发给所述通信对端; 和/或, 接收所述通信对端通过第二连接发送的UDP数据包,所述UDP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包; 将所述UDP数据包重新封装为第一类型数据包; 根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
4.根据权利要求1所述的NAT穿越方法,其特征在于,所述第二请求信息中的协议标识为传输控制协议TCP标识,所述根据所述第二请求信息创建与所述通信对端之间的第二连接,包括: 根据所述第二请求信息中通信对端的IP地址和端口执行与所述通信对端的三次握手过程,从而建立与所述通信对端的TCP通道; 建立所述客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系; 向所述客户端发送通道建立成功响应。
5.根据权利要求4所述的NAT穿越方法,其特征在于,所述根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包,包括: 接收所述客户端通过第一连接发送的第一类型数据包; 将所述第一类型数据包重新封装为TCP数据包; 根据所述对应关系,选择对应的第二连接将所述TCP数据包转发给所述通信对端; 和/或, 接收所述通信对端通过第二连接发送的TCP数据包,所述TCP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包; 将所述TCP数据包重新封装为第一类型数据包; 根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
6.一种服务器,其特征在于,所述服务器包括: 第一接收模块,用于接收客户端向预定地址发送的第一请求信息,所述第一请求信息包括用于建立第一连接的握手信息; 第一创建模块,用于根据所述第一请求信息创建与所述客户端之间的所述第一连接;第二接收模块,用于接收所述客户端通过所述第一连接发送的第二请求信息,所述第二请求信息包括协议标识、通信对端的IP地址和端口 ; 第二创建模块,用于根据所述第二请求信息创建与所述通信对端之间的第二连接;数据传输模块,用于根据所述第一连接和所述第二连接在所述客户端与所述通信对端之间传递数据包。
7.根据权利要求6所述的服务器,其特征在于,所述第二请求信息中的协议标识为用户数据包协议UDP标识,所述第二创建模块,包括: 第一建立单元,用于在本地开设与所述通信对端对应的UDP端口,以便与所述通信对端建立UDP通道; 第二建立单元,用于建立客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系,所述客户端的IP地址和端口是通过所述第一请求信息获取的IP地址和端Π ; 第一发送单元,用于向所述客户端发送通道建立成功响应。
8.根据权利要求7所述的服务器,其特征在于,所述数据传输模块,包括: 第一接收单元,用于接收所述客户端通过第一连接发送的第一类型数据包; 第一封装单元,用于将所述第一类型数据包重新封装为UDP数据包; 第一转发单元,用于根据所述对应关系,选择对应的第二连接将所述UDP数据包转发给所述通信对端; 第二接收单元,用于接收所述通信对端通过第二连接发送的UDP数据包,所述UDP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包; 第二封装单元,用于将所述UDP数据包重新封装为第一类型数据包; 第二转发单元,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
9.根据权利要求6所述的服务器,其特征在于,所述第二请求信息中的协议标识为传输控制协议TCP标识,所述第二创建模块,包括: 第三建立单元,用于根据所述第二请求信息中通信对端的IP地址和端口执行与所述通信对端的三次握手过程,从而建立与所述通信对端的TCP通道; 第四建立单元,用于建立所述客户端的IP地址和端口与所述通信对端的IP地址和端口之间的对应关系; 第二发送单元,用于向所述客户端发送通道建立成功响应。
10.根据权利要求9所述的服务器,其特征在于,所述数据传输模块,包括: 第三接收单元,用于接收所述客户端通过第一连接发送的第一类型数据包;第三封装单元,用于将所述第一类型数据包重新封装为TCP数据包; 第三转发单元,用于根据所述对应关系,选择对应的第二连接将所述TCP数据包转发给所述通信对端; 第四接收单元,用于接收所述通信对端通过第二连接发送的TCP数据包,所述TCP数据包是所述通信对端在接收到所述客户端发送的数据包之后发送的数据包; 第四封装单元,用于将所述TCP数据包 重新封装为第一类型数据包; 第四转发单元,用于根据所述对应关系,选择对应的第一连接将所述第一类型数据包转发给所述客户端。
【文档编号】H04L29/06GK103916485SQ201210594542
【公开日】2014年7月9日 申请日期:2012年12月31日 优先权日:2012年12月31日
【发明者】陈俊兴 申请人:北京新媒传信科技有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1