CN107257345A - 一种基于内外网的数据通讯方法、装置及系统 - Google Patents
一种基于内外网的数据通讯方法、装置及系统 Download PDFInfo
- Publication number
- CN107257345A CN107257345A CN201710547352.2A CN201710547352A CN107257345A CN 107257345 A CN107257345 A CN 107257345A CN 201710547352 A CN201710547352 A CN 201710547352A CN 107257345 A CN107257345 A CN 107257345A
- Authority
- CN
- China
- Prior art keywords
- socket
- proxy server
- server
- intranet
- request message
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/02—Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
- H04L63/0281—Proxies
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/16—Implementation or adaptation of Internet protocol [IP], of transmission control protocol [TCP] or of user datagram protocol [UDP]
- H04L69/161—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields
- H04L69/162—Implementation details of TCP/IP or UDP/IP stack architecture; Specification of modified or new header fields involving adaptations of sockets based mechanisms
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Hardware Design (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
本发明公开了一种基于内外网的数据通讯方法、装置及系统,包括:接收终端通过第一socket发送的第一数据传输请求消息,以及内网服务器通过第二socket发送的第二数据传输请求消息;接收内网服务器发送的socket配对请求消息,生成第一socket和第二socket之间的映射;接收终端通过第一socket传输的数据信息,根据第一socket与第二socket的映射,将数据信息通过第二socket发送至内网服务器。本发明实施例通过代理服务器与内网服务器以及终端的配合,实现了终端与内网服务器之间的通讯,并且在整个过程中并不需要人员的参与,节约了人工成本。
Description
技术领域
本发明涉及公共网络与局域网络通讯领域,尤其涉及一种基于内外网的数据通讯方法、装置及系统。
背景技术
随着互联网的迅猛发展,使用互联网进行通讯得到了广泛的使用。在互联网的通讯中,通讯的双方以特定的互联网协议(Internet Protocal,IP)地址,作为确认通讯双方的来源与目的地址,也就是,网络通讯要求每一个通讯端都需要有一个公共的IP(PublicIP),以作为网络通讯上辨认目的地址之用,这里的网络是指公共网络(Public Network),又称为外部网络。随着企业或单位的一些需求,局域网络(Local Area Network),又称为内部网络,逐渐兴起,内部网络中的用户可以相互联机,但是无法与外部网络直接通讯。一般内部网络中用户与外部网络的通讯采用间接的方式来进行,例如通过网络地址转换(Network Address Translation,NAT)将内部网络中的用户的私有IP转换为NAT本身的公共IP,使外部网络能够加以辨认,从而完成内部网络与外部网络的通讯。
然而采用上述方式完成内部网络与外部网络的通讯,对于一般数据的通讯并无问题;但是话初始协议(Session Initiation Protocal,SIP)所提供的多媒体会议通讯,由于NAT或/和防火墙的存在,在按照SIP通讯协议进行多媒体会议的联机呼叫时,无法呼叫成功,即内部网络与外部网络无法直接进行多媒体会议通讯。
为解决上述问题,现有技术中多采用“路由器端口映射”方案。即在出口路由器上配置内网服务器的某个端口与外部网络的某个端口的映射,从而实现一台内部网络服务器既能向内部网络用户提供服务,又能向外部网络的用户提供服务,完成内部网络与外部网络的通讯。然而该“路由器端口映射”方案需要专业网管人员参与配置路由器规则,从而增加了人工成本,并且不同品牌的路由器的性能也有很大差异,有些路由器并不一定能够支持“路由器端口映射”方案,使得在路由器等硬件挑选方面存在限制。在拨号网络环境下,出口路由器并没有固定的外网IP,即出口路由器在公共网络的IP是在一定范围内变化的,每次变化,内部网络服务器以及外部网络服务器为了保证通讯,都必须重新配置出口路由器,进一步增加了网管人员的配置难度,并且增大了配置错误的可能性,如果配置的不正确将无法实现通讯。
发明内容
本发明提供一种基于内外网的数据通讯方法、装置及系统,用以解决现有技术中内外网多媒体通讯时,路由器不支持,及每次进行出口配置增加配置难度并增大了出现错误的可能性的问题。
为了解决上述问题,依据本发明实施例的一个方面,提供了一种基于内外网的数据通讯方法,包括:
接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;
接收所述内网服务器发送的socket配对请求消息,生成所述第一socket和所述第二socket之间的映射;
接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
进一步地,在所述接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息之前,所述方法还包括:
接收所述终端发送的基础会议GetConferenceBasic请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;
将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;
接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;
将所述GetConferenceBasic响应消息转发至所述终端;
所述接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息包括:
所述IP地址的代理服务器通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
进一步地,在所述接收所述终端发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
接收所述内网服务器发送的第二SIP请求消息,将传输所述第二SIP请求消息的第二传输控制协议TCP socket保存为SIPS socket;
所述将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器包括:
将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPS socket转发至所述内网服务器。
进一步地,在所述接收内网服务器通过第二socket发送的第二数据传输请求消息之前,所述方法还包括:
接收所述终端发送的第一会话初始协议SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
进一步地,所述将所述第一SIP请求消息转发至内网服务器,包括:
将所述第一SIP请求消息中的联络地址信息替换为所述代理服务器的IP地址;
将地址替换后的第一SIP请求消息转发至所述内网服务器。
进一步地,在将所述第一SIP请求消息转发至内网服务器之前,所述方法还包括:
解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;
根据所述源端的标识信息以及发送所述第一SIP请求消息的第一传输控制协议套接字TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
进一步地,在所述将所述第一SIP请求消息转发至内网服务器之后,所述方法还包括:
接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;
根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCP socket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
依据本发明实施例的又一个方面,提供了一种基于内外网的数据通讯方法,包括:
通过第二套接字socket向代理服务器发送第二数据传输请求消息;
向所述代理服务器发送套接字socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket;
接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
进一步地,在所述通过第二套接字socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:
接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;
解析所述GetConferenceBasic请求消息;
若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;
将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;
所述通过第二socket向所述代理服务器发送第二数据传输请求消息包括:
根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
进一步地,在所述接收所述代理服务器发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPS socket,并采用保存的所述SIPSsocket转发所述GetConferenceBasic请求消息。
进一步地,在所述通过第二套接字socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:
接收第一会话初始协议SIP请求消息;
解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;
若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送套接字socket配对请求消息。
依据本发明实施例的又一个方面,提供了一种基于内外网的数据通讯装置,所述装置包括:
媒体流代理模块,用于接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;
代理服务模块,用于接收所述内网服务器发送的socket配对请求消息;
所述媒体流代理模块,还用于生成所述第一socket和所述第二socket之间的映射;接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
进一步地,所述装置还包括:会话初始协议代理模块,用于接收所述终端发送的基础会议GetConferenceBasic请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;将所述GetConferenceBasic响应消息转发至所述终端;所述媒体流代理模块,具体用于通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
进一步地,所述会话初始协议代理模块,还用于接收所述内网服务器发送的第二SIP请求消息,将传输所述第二SIP请求消息的第二传输控制协议TCP socket保存为SIPSsocket;将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPS socket转发至所述内网服务器。
进一步地,所述会话初始协议代理模块,还用于接收所述终端发送的第一会话初始协议SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
进一步地,所述会话初始协议代理模块,具体用于将所述第一SIP请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址替换后的第一SIP请求消息转发至所述内网服务器。
进一步地,所述会话初始协议代理模块,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;根据所述源端的标识信息以及发送所述第一SIP请求消息的第一传输控制协议套接字TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
进一步地,所述会话初始协议代理模块,还用于接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCPsocket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
依据本发明实施例的又一个方面,提供了一种基于内外网的数据通讯装置,所述装置包括:
媒体流服务模块,通过第二套接字socket向代理服务器发送第二数据传输请求消息;
内网服务模块,还用于向所述代理服务器发送套接字socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket;
所述媒体流服务模块,还用于接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
进一步地,所述装置还包括:会话初始协议服务模块,用于接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;解析所述GetConferenceBasic请求消息;若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;所述媒体流服务模块,具体用于根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
进一步地,所述会话初始协议服务模块,还用于发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPS socket,并采用保存的所述SIPS socket转发所述GetConferenceBasic请求消息。
进一步地,所述会话初始协议服务模块,还用于接收第一会话初始协议SIP请求消息;所述内网服务模块,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送套接字socket配对请求消息。
依据本发明实施例的又一个方面,提供了一种基于内外网的数据通讯系统,包括上述应用于代理服务器的基于内外网的数据通讯装置,上述应用于内网服务器的基于内外网的数据通讯装置,以及与上述内网服务器进行数据通讯的位于外部网络的终端。
本发明有益效果如下:
本发明实施例提供了一种基于内外网的数据通讯的方法、装置及系统,该方法中通过接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;接收所述内网服务器发送的socket配对请求消息,生成所述第一socket和所述第二socket之间的映射;接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。由于本发明实施例通过代理服务器完成内网服务器与位于外部网络的终端之间的通讯,无需人工在出口路由器上配置内网服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
附图说明
图1为本发明实施例1提供的一种基于内外网的数据通讯方法示意图;
图2为本发明实施例2提供的一种基于内外网的数据通讯过程示意图;
图3为本发明实施例4提供的一种基于内外网的数据通讯过程示意图;
图4为本发明实施例5提供的一种基于内外网的数据通讯方法示意图;
图5为本发明实施例6提供的一种基于内外网的数据通讯过程示意图;
图6为本发明实施例7提供的一种基于内外网的数据通讯过程示意图;
图7为本发明实施例8提供的一种基于内外网的数据通讯装置示意图;
图8为本发明实施例提供9的一种基于内外网的数据通讯装置示意图;
图9为本发明实施例提供10的一种基于内外网的数据通讯装系统示意图。
具体实施方式
下面结合说明书附图,对本发明实施例提供的一种基于内外网的数据通讯方法、装置及系统的具体实施方式进行说明。
实施例1:
本发明实施例提供了一种基于内外网的数据通讯方法,如图1所示,包括以下步骤:
S11:接收位于外部网络的终端通过第一套接字(socket)发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息。
本发明实施例提供的基于内外网的数据通讯方法应用于代理服务器,较佳地,为云代理服务器。
外部网络也可以称为公共网络,内部网络也可以称为局域网络,当位于外部网络的终端与位于内部网络中的终端进行多媒体会议时,位于外部网络的终端主动接入内部网络,从而进行多媒体会议。这里的第一数据传输请求消息用于建立位于外部网络的终端与代理服务器之间的第一数据信息交互通道;第二数据传输请求消息用于建立内网服务器与代理服务器之间的第二数据信息交互通道,第一数据信息交互通道为第一socket,第二数据信息交互通道为第二socket,因此,第一数据传输请求消息与第二数据传输请求消息可以是网络连接(raknet)请求消息,也可以是用户数据报协议(User Datagram Protocol,UDP)请求消息。
当所述数据传输请求消息为raknet请求消息时,具体的,接收位于外部网络的终端通过第一套接字(socket)发送的第一数据传输请求消息包括:接收位于外部网络的终端通过第一套接字(socket)发送的第一网络连接raknet请求消息;
接收内网服务器通过第二socket发送的第二数据传输请求消息包括:接收内网服务器通过第二socket发送的第二raknet请求消息。
S12:接收所述内网服务器发送的socket配对请求消息,生成所述第一socket和所述第二socket之间的映射。
为了实现位于外部网络的终端与内网服务器之间的数据传输,在第一socket和第二socket建立之后。代理服务器接收socket配对请求消息,建立第一socket和第二socket之间的映射。
因为位于外部网络的终端与内网服务器之间数据信息的交互是通过代理服务器转发完成的,这样通过第一socket和第二socket之间的映射就可以将位于外部网络的终端通过第一socket发送的数据信息通过第二socket发送至内网服务器。
S13:接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
代理服务器生成了第一socket和第二socket之间的映射,因此位于外部网络的终端与内网服务器之间可以进行数据信息的交互。终端可以通过第一socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第一socket映射的第二socket,将该数据信息通过第二socket发送至内网服务器,数据信息的交互是双向的,当然也可以是内网服务器通过第二socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第二socket映射的第一socket,将该数据信息通过第一socket发送至终端。
本发明实施例通过代理服务器完成内网服务器与位于外部网络的终端之间的通讯,无需人工在出口路由器上配置内网服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
实施例2:
为了实现位于外部网络的终端与代理服务器之间的数据信息交互通道的建立,因此在上述实施例的基础上,本发明实施例中,在所述接收位于外部网络的终端通过第一socket发送的第一数据传输请求消息之前,所述方法还包括:
接收所述终端发送的基础会议(GetConferenceBasic)请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;
将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;
接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;
将所述GetConferenceBasic响应消息转发至所述终端;
所述接收位于外部网络的终端通过第一socket发送的第一数据传输请求消息包括:
所述IP地址的代理服务器通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
第一数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息,第一数据传输请求消息用于建立位于外部网络的终端与代理服务器之间的第一数据信息交互通道。
应当说明的是,可以在GetConferenceBasic请求消息中添加contact字段保存联络地址信息,代理服务器将接收到的GetConferenceBasic请求消息的contact字段中的内容替换为本身的IP地址,内网服务器预存有代理服务器的信息,具体的包括:若第一数据传输请求消息是raknet请求消息,内网服务器预存有代理服务器的IP地址(cloudProxyIP),raknet代理端口(proxyRaknetPort),但不仅限于此,并且代理服务器的IP地址与raknet代理端口相对应,当代理服务器的IP地址确定后,相应的raknet代理端口也会确定
如果内网服务器检测到GetConferenceBasic请求消息的contact字段中的IP地址与自身预存的cloudProxyIP相同,内网服务器将在针对GetConferenceBasic请求消息的GetConferenceBasic响应消息中,添加自身预存的cloudProxyIP以及与该cloudProxyIP对应的proxyRaknetPort,使得发送GetConferenceBasic请求消息的终端接收到代理服务器转发的GetConferenceBasic响应消息时,向GetConferenceBasic响应消息中携带的IP地址的代理服务器的raknet端口发送第一raknet请求消息。
若第一数据传输请求消息是UDP请求消息,内网服务器预存有代理服务器的IP地址(cloudProxyIP),UDP代理端口(proxyUDPPort),但不仅限于此,并且代理服务器的IP地址与UDP代理端口相对应,当代理服务器的IP地址确定后,相应的UDP代理端口也会确定。
如果内网服务器检测到GetConferenceBasic请求消息的contact字段中的IP地址与自身预存的cloudProxyIP相同,内网服务器将在针对GetConferenceBasic请求消息的GetConferenceBasic响应消息中,添加自身预存的cloudProxyIP以及与该cloudProxyIP对应的proxyUDPPort,使得发送GetConferenceBasic请求消息的终端接收到代理服务器转发的GetConferenceBasic响应消息时,向GetConferenceBasic响应消息中携带的IP地址的代理服务器的UDP端口发送第一UDP请求消息。
为了实现内网服务器与代理服务器之间的信令交互,本发明实施例中,在所述接收所述终端发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
接收所述内网服务器发送的第二会话初始协议(Session Initiation Protocol,SIP)请求消息,将传输所述第二SIP请求消息的第二传输控制协议(Transmission ControlProtocol,TCP)socket保存为SIPS socket;
所述将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器包括:
将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPS socket转发至所述内网服务器。
为了实现内网服务器与代理服务器之间的信令交互,内网服务器预存有代理服务器的信息,具体的包括:代理服务器的IP地址(cloudProxyIP)和代理服务器的SIP代理端口(proxySipPort)。内网服务器根据预存的代理服务器的信息,向代理服务器的proxySipPort发送第二SIP请求消息,即通过第二TCP socket向代理服务器主动发送第二SIP请求消息,建立代理服务与内网服务器之间的信令交互通道。代理服务器接收到GetConferenceBasic请求消息后,通过建立起的代理服务器与内网服务器之间的信令交互通道,将该GetConferenceBasic请求消息转发至内网服务器。并且在该SIP会话的过程中,后续内网服务器与代理服务器之间的信令交互都可以通过该SIPS socket进行发送,从而实现内网服务器与代理服务器之间连接的复用。
图2为本发明实施例提供的一种基于内外网的数据通讯过程示意图,该过程包括以下步骤:
S201:内网服务器通过第二TCP socket发送第二SIP请求消息至代理服务器。
S202:代理服务器将第二TCP socket保存为SIPS socket。
S203:位于外部网络的终端发送GetConferenceBasic请求消息至代理服务器。
S204:代理服务器将GetConferenceBasic请求消息中的联络地址信息替换为代理服务器的IP地址。
S205:代理服务器将地址替换后的GetConferenceBasic请求消息通过SIPSsocket转发至内网服务器。
S206:内网服务器发送GetConferenceBasic响应消息至代理服务器,其中GetConferenceBasic响应消息中携带代理服务器的IP地址及代理服务器的raknet端口号。
应当说明的是,代理服务器的IP地址及代理服务器的raknet端口号为内网服务器根据保存的代理服务器与其IP地址、raknet端口号的对应关系,在接收到代理服务器发送的GetConferenceBasic请求消息后确定的。例如内网服务器保存有代理服务器A的IP地址以及raknet端口号,当内网服务器接收到GetConferenceBasic请求消息后,检测到GetConferenceBasic请求消息的联络地址信息与代理服务器A的IP地址相同,则将代理服务A的IP地址以及raknet端口号添加到针对GetConferenceBasic请求消息生成的GetConferenceBasic响应消息中。
S207:代理服务器将GetConferenceBasic响应消息转发至位于外部网络的终端。
S208:位于外部网络的终端发送第一raknet请求消息至代理服务器。
S209:内网服务器发送第二raknet请求消息至代理服务器。
S210:内网服务器发送socket配对请求消息至代理服务器。
S211:代理服务器根据第一raknet请求消息、第二raknet请求消息和socket配对请求消息,生成第一socket和第二socket之间的映射,其中第一socket为终端与代理服务器之间的socket,第二socket为内网服务器与代理服务器之间的socket。
S212:位于外部网络的终端通过第一socket发送数据信息至代理服务器。
S213:代理服务器根据第一socket与第二socket的映射,将数据信息通过第二socket转发至内网服务器。
实施例3:
为了建立位于外部网络的终端与内网服务器之间的会话,在上述各实施例的基础上,本发明实施例中,在所述接收内网服务器通过第二socket发送的第二数据传输请求消息之前,所述方法还包括:
接收所述终端发送的第一SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
为了实现内网服务器与代理服务器之间的信令交互,并后续实现终端与内网服务器之间数据信息的传输,因此在上述实施例的基础上,本发明实施例中,所述将第一SIP请求消息转发至内网服务器,包括:
将第一SIP请求消息中的联络地址信息替换为代理服务器的IP地址;
将地址替换后的第一SIP请求消息转发至内网服务器。
第一SIP请求消息可以是邀请(INVITE)请求,位于外部网络的终端通过INVITE请求向内网服务器发起会话。每个内网服务器通过特定的代理服务器完成与外部网络的终端的数据交互,因此为了保证数据传输的合法性,内网服务器预存有其对应的代理服务器的信息,具体的包括:代理服务器的IP地址(cloudProxyIP),但不仅限于此。当代理服务器接收到位于外部网络的终端发送的第一SIP请求消息后,将第一SIP请求消息中的联络地址信息替换为代理服务器的IP地址,内网服务器检测第一SIP请求消息的联络地址信息与自身预存的cloudProxyIP是否相同,若相同,则内网服务器就会与代理服务器进行后续通讯,否则,对该第一SIP请求消息不进行后续处理。该方法既保证了代理服务器与内网服务器能够进行通讯,同时也避免了没有在内网服务器上保存IP地址的代理服务器的干扰。
实施例4:
为了保证生成的第一SIP响应消息,能够准确传输至发送第一SIP请求消息的终端,在上述各实施例的基础上,本发明实施例中,在将所述第一SIP请求消息转发至内网服务器之前,所述方法还包括:解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;
根据所述源端的标识信息以及发送所述第一SIP请求消息的第一TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
在所述将所述第一SIP请求消息转发至内网服务器之后,所述方法还包括:
接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;
根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCP socket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
本发明实施例中,第一数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息,对应的第二数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息。SIP请求消息中的不同字段携带不同信息,例如from字段携带了该SIP消息的源端,to字段携带了该SIP消息的目的端。在本发明实施例中通过解析来自终端的第一SIP请求消息的from字段就可以得到发送该第一SIP请求消息的终端的标识信息(identification,ID)。为了保证SIP响应消息的发送,代理服务器在本地建立终端的ID与终端发送第一SIP请求消息的第一TCP socket的映射。因为针对第一SIP请求消息的第一SIP响应消息携带的from字段与该第一SIP请求消息的from字段相同,因此当代理服务器接收到第一SIP响应消息时,解析其from字段得到终端的ID,根据建立的终端的ID与第一TCP socket的映射,通过第一TCPsocket将该第一SIP响应消息转发至终端。
具体的终端A的ID为AA,终端A通过AATCP socket发送第一SIP请求消息至代理服务器,代理服务器接收该第一SIP请求消息,并解析第一SIP请求消息的from字段的内容得到终端A的ID为AA,建立AA与AATCP socket的映射,代理服务器将第一SIP请求消息转发至内网服务器;然后接收内网服务器根据第一SIP请求消息生成的第一SIP响应消息,第一SIP响应消息的from字段的内容与第一SIP请求消息的from字段的内容相同,代理服务器接收第一SIP响应消息并解析得到第一SIP响应消息的from字段的内容为AA,根据AA与AATCPsocket的映射,将第一SIP响应消息通过AATCP socket发送至ID为AA的终端。
图3为本发明实施例提供的一种基于内外网的数据通讯过程示意图,该过程包括以下步骤:
S301:内网服务器通过第二TCP socket发送第二SIP请求消息至代理服务器。
S302:代理服务器将第二TCP socket保存为SIPS socket。
S303:位于外部网络的终端发送GetConferenceBasic请求消息至代理服务器。
S304:代理服务器将GetConferenceBasic请求消息中的联络地址信息替换为代理服务器的IP地址。
S305:代理服务器将地址替换后的GetConferenceBasic请求消息通过SIPSsocket转发至内网服务器。
S306:内网服务器发送GetConferenceBasic响应消息至代理服务器,其中GetConferenceBasic响应消息中携带代理服务器的IP地址及代理服务器的raknet端口号。
应当说明的是,代理服务器的IP地址及代理服务器的raknet端口号为内网服务器根据保存的代理服务器与其IP地址、raknet端口号的对应关系,在接收到代理服务器发送的GetConferenceBasic请求消息后确定的。例如内网服务器保存有代理服务器A的IP地址以及raknet端口号,当内网服务器接收到GetConferenceBasic请求消息后,检测到GetConferenceBasic请求消息的联络地址信息与代理服务器A的IP地址相同,则将代理服务A的IP地址以及raknet端口号添加到针对GetConferenceBasic请求消息生成的GetConferenceBasic响应消息中。
S307:代理服务器将GetConferenceBasic响应消息转发至位于外部网络的终端。
S308:位于外部网络的终端发送第一raknet请求消息至代理服务器。
S309:位于外部网络的终端发送第一SIP请求消息至代理服务器。
S310:代理服务器将第一SIP请求消息中的联络地址信息替换为本身的IP地址。
S311:代理服务器将地址替换后的第一SIP请求消息通过SIPS socket转发至内网服务器。
S312:内网服务器发送第二raknet请求消息至代理服务器。
S313:内网服务器发送socket配对请求消息至代理服务器。
S314:代理服务器根据第一raknet请求消息、第二raknet请求消息和socket配对请求消息,生成第一socket和第二socket之间的映射,其中第一socket为终端与代理服务器之间的socket,第二socket为内网服务器与代理服务器之间的socket。
S315:内网服务器发送第一SIP响应消息至代理服务器。
这里的第一SIP响应消息为内网服务器根据第一SIP请求消息生成的,具体为会话连接成功消息,若会话连接不成功,则根据现有技术终端会继续发送第一SIP请求消息,在此不再赘述。
S316:代理服务器转发第一SIP响应消息至位于外部网络的终端。
S317:位于外部网络的终端通过第一socket发送数据信息至代理服务器。
S318:代理服务器根据第一socket与第二socket的映射,将数据信息通过第二socket转发至内网服务器。
实施例5:
本发明实施例提供了一种基于内外网的数据通讯方法,如图4所示,包括以下步骤:
S41:通过第二socket向代理服务器发送第二数据传输请求消息。
本发明实施例提供的基于内外网的数据通讯方法应用于内网服务器,外部网络也可以称为公共网络,内部网络也可以称为局域网络,位于内部网络的服务器称为内网服务器,当位于外部网络的终端与内部网络中的终端进行多媒体会议时,位于外部网络的终端主动接入内部网络,从而进行多媒体会议。第二数据传输请求消息用于建立内网服务器与代理服务器之间的第二数据信息交互通道,第二数据信息交互通道为第二socket。第二数据传输请求消息可以是网络连接(raknet)请求消息,也可以是用户数据报协议(UserDatagram Protocol,UDP)请求消息。
当所述数据传输请求消息为raknet请求消息时,具体的,通过第二socket向代理服务器发送第二数据传输请求消息包括:通过第二socket向代理服务器发送第二raknet请求消息。
S42:向所述代理服务器发送套接字socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket。
为了实现位于外部网络的终端与内网服务器之间的数据传输,在第一socket和第二socket建立之后。当代理服务器接收到socket配对请求消息之后,建立第一socket和第二socket之间的映射。
因为位于外部网络的终端与内网服务器之间数据信息的交互是通过代理服务器转发完成的,这样通过第一socket和第二socket之间的映射就可以将位于外部网络的终端通过第一socket发送的数据信息通过第二socket发送至内网服务器。
S43:接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
代理服务器生成了第一socket和第二socket之间的映射,因此位于外部网络的终端与内网服务器之间可以进行数据信息的交互。终端可以通过第一socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第一socket映射的第二socket,将该数据信息通过第二socket发送至内网服务器,数据信息的交互是双向的,当然也可以是内网服务器通过第二socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第二socket映射的第一socket,将该数据信息通过第一socket发送至终端。
本发明实施例通过代理服务器完成内网服务器与位于外部网络的终端之间的通讯,无需人工在出口路由器上配置内部网络服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
实施例6:
为了实现位于外部网络的终端与代理服务器之间的数据信息交互通道的建立,在上述实施例的基础上,本发明实施例中,在所述通过第二socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:
接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;
解析所述GetConferenceBasic请求消息;
若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;
将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;
所述通过第二socket向所述代理服务器发送第二数据传输请求消息包括:
根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
第二数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息,第二数据传输请求消息用于建立内网服务器与代理服务器之间的第二数据信息交互通道。
应当说明的是,可以在GetConferenceBasic请求消息中添加contact字段保存联络地址信息,代理服务器将接收到的GetConferenceBasic请求消息的contact字段中的内容替换为本身的IP地址,内网服务器预存有代理服务器的信息,具体的包括:若第二数据传输请求消息是raknet请求消息,内网服务器预存有代理服务器的IP地址(cloudProxyIP),raknet代理端口(proxyRaknetPort),但不仅限于此,并且代理服务器的IP地址与raknet代理端口相对应,当代理服务器的IP地址确定后,相应的raknet代理端口也会确定。
如果内网服务器检测到GetConferenceBasic请求消息的contact字段中的IP地址与自身预存的cloudProxyIP相同,内网服务器将在针对GetConferenceBasic请求消息的GetConferenceBasic响应消息中,添加自身预存的cloudProxyIP以及与该cloudProxyIP对应的proxyRaknetPort,使得发送GetConferenceBasic请求消息的终端接收到代理服务器转发的GetConferenceBasic响应消息时,向GetConferenceBasic响应消息中携带的IP地址的代理服务器的raknet端口发送第一raknet请求消息,内网服务器根据自身预存的cloudProxyIP以及与该cloudProxyIP对应的proxyRaknetPort,向所述IP地址的代理服务器的raknet端口发送第二raknet请求消息。
若第二数据传输请求消息是UDP请求消息,内网服务器预存有代理服务器的IP地址(cloudProxyIP),UDP代理端口(proxyUDPPort),但不仅限于此,并且代理服务器的IP地址与UDP代理端口相对应,当代理服务器的IP地址确定后,相应的UDP代理端口也会确定。
如果内网服务器检测到GetConferenceBasic请求消息的contact字段中的IP地址与自身预存的cloudProxyIP相同,内网服务器将在针对GetConferenceBasic请求消息的GetConferenceBasic响应消息中,添加自身预存的cloudProxyIP以及与该cloudProxyIP对应的proxyUDPPort,使得发送GetConferenceBasic请求消息的终端接收到代理服务器转发的GetConferenceBasic响应消息时,向GetConferenceBasic响应消息中携带的IP地址的代理服务器的UDP端口发送第二UDP请求消息。
为了实现内网服务器与代理服务器之间的信令交互,本发明实施例中,在所述接收所述代理服务器发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPS socket,并采用保存的所述SIPSsocket转发所述GetConferenceBasic请求消息。
为了实现内网服务器与代理服务器之间的信令交互,内网服务器预存有代理服务器的信息,具体的包括:代理服务器的IP地址(cloudProxyIP)和代理服务器的SIP代理端口(proxySipPort)。内网服务器根据预存的代理服务器的信息,向代理服务器的proxySipPort发送第二SIP请求消息,即通过第二TCP socket向代理服务器主动发送第二SIP请求消息,建立代理服务与内网服务器之间的信令交互通道。代理服务器接收到GetConferenceBasic请求消息后,通过建立起的代理服务器与内网服务器之间的信令交互通道,将该GetConferenceBasic请求消息转发至内网服务器。并且在该SIP会话的过程中,后续内网服务器与代理服务器之间的信令交互都可以通过该SIPS socket进行发送,从而实现内网服务器与代理服务器之间连接的复用。
图5为本发明实施例提供的一种基于内外网的数据通讯过程示意图,该过程包括以下步骤:
S501:内网服务器通过第二TCP socket发送第二SIP请求消息至代理服务器。
S502:代理服务器将第二TCP socket保存为SIPS socket。
S503:位于外部网络的终端发送GetConferenceBasic请求消息至代理服务器。
S504:代理服务器将GetConferenceBasic请求消息中的联络地址信息替换为代理服务器的IP地址。
S505:代理服务器将地址替换后的GetConferenceBasic请求消息通过SIPSsocket转发至内网服务器。
S506:内网服务器发送GetConferenceBasic响应消息至代理服务器,其中GetConferenceBasic响应消息中携带代理服务器的IP地址及代理服务器的raknet端口号。
应当说明的是,代理服务器的IP地址及代理服务器的raknet端口号为内网服务器根据保存的代理服务器与其IP地址、raknet端口号的对应关系,在接收到代理服务器发送的GetConferenceBasic请求消息后确定的。例如内网服务器保存有代理服务器A的IP地址以及raknet端口号,当内网服务器接收到GetConferenceBasic请求消息后,检测到GetConferenceBasic请求消息的联络地址信息与代理服务器A的IP地址相同,则将代理服务A的IP地址以及raknet端口号添加到针对GetConferenceBasic请求消息生成的GetConferenceBasic响应消息中。
S507:代理服务器将GetConferenceBasic响应消息转发至位于外部网络的终端。
S508:位于外部网络的终端发送第一raknet请求消息至代理服务器。
S509:内网服务器发送第二raknet请求消息至代理服务器。
S510:内网服务器发送socket配对请求消息至代理服务器。
S511:代理服务器根据第一raknet请求消息、第二raknet请求消息和socket配对请求消息,生成第一socket和第二socket之间的映射,其中第一socket为终端与代理服务器之间的socket,第二socket为内网服务器与代理服务器之间的socket。
S512:位于外部网络的终端通过第一socket发送数据信息至代理服务器。
S513:代理服务器根据第一socket与第二socket的映射,将数据信息通过第二socket转发至内网服务器。
实施例7:
为了建立位于外部网络的终端与内网服务器之间的会话,在上述各实施例的基础上,本发明实施例中,在所述通过第二socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:接收第一SIP请求消息;
解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;
若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送socket配对请求消息。
本发明实施例中,第一数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息,对应的第二数据传输请求消息可以是raknet请求消息,也可以是UDP请求消息。
应当说明的是,第一SIP请求消息可以是邀请(INVITE)请求,位于外部网络的终端通过INVITE请求向内网服务器发起会话。位于外网的终端在接收到内网服务器发送的针对第一SIP请求消息的第一SIP响应消息之后才会发送数据信息至代理服务器。
图6为本发明实施例提供的一种基于内外网的数据通讯过程示意图,该过程包括以下步骤:
S601:内网服务器通过第二TCP socket发送第二SIP请求消息至代理服务器。
S602:代理服务器将第二TCP socket保存为SIPS socket。
S603:位于外部网络的终端发送GetConferenceBasic请求消息至代理服务器。
S604:代理服务器将GetConferenceBasic请求消息中的联络地址信息替换为代理服务器的IP地址。
S605:代理服务器将地址替换后的GetConferenceBasic请求消息通过SIPSsocket转发至内网服务器。
S606:内网服务器发送GetConferenceBasic响应消息至代理服务器,其中GetConferenceBasic响应消息中携带代理服务器的IP地址及代理服务器的raknet端口号。
应当说明的是,代理服务器的IP地址及代理服务器的raknet端口号为内网服务器根据保存的代理服务器与其IP地址、raknet端口号的对应关系,在接收到代理服务器发送的GetConferenceBasic请求消息后确定的。例如内网服务器保存有代理服务器A的IP地址以及raknet端口号,当内网服务器接收到GetConferenceBasic请求消息后,检测到GetConferenceBasic请求消息的联络地址信息与代理服务器A的IP地址相同,则将代理服务A的IP地址以及raknet端口号添加到针对GetConferenceBasic请求消息生成的GetConferenceBasic响应消息中。
S607:代理服务器将GetConferenceBasic响应消息转发至位于外部网络的终端。
S608:位于外部网络的终端发送第一raknet请求消息至代理服务器。
S609:位于外部网络的终端发送第一SIP请求消息至代理服务器。
S610:代理服务器将第一SIP请求消息中的联络地址信息替换为本身的IP地址。
S611:代理服务器将地址替换后的第一SIP请求消息通过SIPS socket转发至内网服务器。
S612:内网服务器发送第二raknet请求消息至代理服务器。
S613:内网服务器发送socket配对请求消息至代理服务器。
S614:代理服务器根据第一raknet请求消息、第二raknet请求消息和socket配对请求消息,生成第一socket和第二socket之间的映射,其中第一socket为终端与代理服务器之间的socket,第二socket为内网服务器与代理服务器之间的socket。
S615:内网服务器发送第一SIP响应消息至代理服务器。
这里的第一SIP响应消息为内网服务器根据第一SIP请求消息生成的,具体为会话连接成功消息,若会话连接不成功,则根据现有技术终端会继续发送第一SIP请求消息,在此不再赘述。
S616:代理服务器转发第一SIP响应消息至位于外部网络的终端。
S617:位于外部网络的终端通过第一socket发送数据信息至代理服务器。
S618:代理服务器根据第一socket与第二socket的映射,将数据信息通过第二socket转发至内网服务器。
实施例8:
基于同一发明构思,本发明的又一实施例提供了一种基于内外网的数据通讯装置,如图7所示,该装置包括:
媒体流代理模块73,用于接收位于外部网络的终端通过第一socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;
代理服务模块72,用于接收所述内网服务器发送的socket配对请求消息;
所述媒体流代理模块73,还用于生成所述第一socket和所述第二socket之间的映射;接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
会话初始协议代理模块71,用于接收所述终端发送的基础会议GetConferenceBasic请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;将所述GetConferenceBasic响应消息转发至所述终端;所述媒体流代理模块73,具体用于通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
所述会话初始协议代理模块71,还用于接收所述内网服务器发送的第二SIP请求消息,将传输所述第二SIP请求消息的第二传输控制协议TCP socket保存为SIPS socket;将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPS socket转发至所述内网服务器。
所述会话初始协议代理模块71,还用于接收所述终端发送的第一SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
所述会话初始协议代理模块71,具体用于将所述第一SIP请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址替换后的第一SIP请求消息转发至所述内网服务器。
所述会话初始协议代理模块71,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;根据所述源端的标识信息以及发送所述第一SIP请求消息的第一TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
所述会话初始协议代理模块71,还用于接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCP socket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
本发明实施例提供的该基于内外网的数据通讯装置应用于代理服务器。
代理服务器生成了第一socket和第二socket之间的映射,因此位于外部网络的终端与内网服务器之间可以进行数据信息的交互。终端可以通过第一socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第一socket映射的第二socket,将该数据信息通过第二socket发送至内网服务器。该过程无需人工在出口路由器上配置内部网络服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
实施例9:
本发明的又一实施例提供了一种基于内外网的数据通讯装置,如图8所示,该装置包括:
媒体流服务模块83,通过第二socket向代理服务器发送第二数据传输请求消息;
内网服务模块82,用于向所述代理服务器发送socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket;
所述媒体流服务模块83,还用于接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
会话初始协议服务模块81,用于接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;解析所述GetConferenceBasic请求消息;若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;所述媒体流服务模块83,具体用于根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
所述会话初始协议服务模块81,还用于发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPSsocket,并采用保存的所述SIPS socket转发所述GetConferenceBasic请求消息。
所述会话初始协议服务模块81,还用于接收第一会SIP请求消息;所述内网服务模块,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送socket配对请求消息。
本发明实施例提供的基于内外网的数据通讯装置应用于内网服务器。
代理服务器生成了第一socket和第二socket之间的映射,因此位于外部网络的终端与内网服务器之间可以进行数据信息的交互。终端可以通过第一socket将数据信息发送给代理服务器,代理服务器根据生成的第一socket和第二socket之间的映射,查找该第一socket映射的第二socket,将该数据信息通过第二socket发送至内网服务器。该过程无需人工在出口路由器上配置内部网络服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
实施例10:
图9为本发明实施例提供的一种基于内外网的数据通讯系统结构示意图,所述系统包括图7所示的应用于代理服务器91的基于内外网的数据通讯装置、图8所示的应用于内网服务器92的基于内外网的数据通讯装置、以及位于外部网络的终端93。
现结合图9,对位于外部网络的终端93和内网服务器92之间的数据通讯过程进行详细说明。
内网服务器92通过会话初始协议服务模块发送第二SIP请求消息至代理服务器91;代理服务器91通过会话初始协议代理模块接收该第二SIP请求消息并将传输该第二SIP请求消息的TCP socket标记为SIPS socket,并进行存储。
位于外部网络的终端93发送GetConferenceBasic请求消息至代理服务器91,代理服务器91通过会话初始协议代理模块将GetConferenceBasic请求消息的联络地址信息替换为代理服务器91的IP地址,并将地址替换后的GetConferenceBasic请求消息通过SIPSsocket转发至内网服务器92。
内网服务器92预存有代理服务器91的IP地址以及与代理服务器91的IP地址对应的数据端口号,内网服务器92通过会话初始协议服务模块接收GetConferenceBasic请求消息,若检测到GetConferenceBasic请求消息的联络地址信息与预存的代理服务器91的IP地址相同,生成GetConferenceBasic响应消息并添加该预存的代理服务器91的IP地址以及与该IP地址对应的数据端口号,并且将该GetConferenceBasic响应消息通过SIPS socket发送至代理服务器91。
代理服务器91通过会话初始协议代理模块接收该GetConferenceBasic响应消息,并转发至位于外部网络的终端93。位于外部网络的终端93根据GetConferenceBasic响应消息中代理服务器91的IP地址以及相应的数据端口号,向代理服务器91相应的数据端口号发送第一数据传输请求。
上述为建立位于外部网络的终端93与代理服务器91之间的第一数据信息交互通道的过程。
为了建立内网服务器92与位于外部网络的终端93之间的会话,以及建立内网服务器92与代理服务器91之间的第二数据信息交互通道,并且将第一数据信息交互通道和第二数据信息交互通道进行配对,从而保证位于外部网络的终端93发送的数据信息能够传输到内网服务器92。位于外部网络的终端93发送第一SIP请求消息至代理服务器91,代理服务器91通过会话初始协议代理模块接收第一SIP请求消息并解析第一SIP请求消息中携带的源端的标识信息,得到位于外部网络的终端93的标识信息,建立位于外部网络的终端93的标识信息与传输第一SIP请求消息的TCP socket之间的映射。在上述过程中代理服务器解析第一SIP请求消息的from字段,得到传输第一SIP请求消息的位于外部网络的终端93的ID,这里每个终端的ID各不相同,建立该终端的ID与发送第一SIP请求消息的TCP socket的映射,例如位于外部网络的终端93的ID为AA,传输第一SIP请求消息的TCP socket为AATCPsocket,则建立AA到AATCP socket的映射。
代理服务器91通过会话初始协议代理模块将第一SIP请求消息中的联络地址信息替换为代理服务器91的IP地址,并将地址替换后的第一SIP请求消息,通过SIPS socket转发至内网服务器92。
内网服务器92预存有代理服务器91的IP地址以及与该IP地址对应的数据端口号,内网服务器92通过内网服务模块解析第一SIP请求消息,若得到的第一SIP请求消息的联络地址信息与预存的代理服务器91的IP地址相同,内网服务器92根据预存的代理服务器91的IP地址以及与该IP地址对应的数据端口号通过媒体流服务模块向代理服务器91的相应的数据端口发送第二数据请求。具体的,内网服务器92生成并发送增加客户端(AddClient)消息至媒体流服务模块,并在AddClient消息中添加网络连接代理端口(proxyRaknetPort)、源自代理(fromProxy)字段并对其对应的内容进行设置,例如将fromProxy字段对应的内容设置为true,将proxyRaknetPort字段对应的内容设置为内网服务器91预存的proxyRaknetPort端口号,当然添加的字段也不仅限于此;媒体流服务模块检测到AddClient消息中带有fromProxy字段并且该字段对应的内容为true,媒体流服务模块创建raknetClient,并根据proxyRaknetPort字段的内容向代理服务器91相应的数据端口号发送第二数据传输请求。内网服务器92发送socket配对请求消息至代理服务器91,较佳的,socket配对请求消息携带有位于外部网络的终端93的发送第一数据传输请求的终端端口号和内网服务器92的发送第二数据传输请求的内网服务器端口号。
代理服务器91的代理服务模块根据socket配对请求消息,建立传输位于外部网络的终端93发送的第一数据传输请求的第一socket与传输内网服务器92发送的第二数据传输请求的第二socket之间的映射。
内网服务器92通过会话初始协议服务模块根据第一SIP请求消息生成第一SIP响应消息,并发送至代理服务器91,代理服务器91的会话初始协议代理模块解析第一SIP响应消息,将第一SIP响应消息转发至位于外部网络的终端93,具体的,因为第一SIP响应消息from字段对应的内容与第一SIP请求消息from字段对应的内容相同,得到第一SIP响应消息中from字段对应的内容即位于外部网络的终端93的ID,根据该ID与TCP socket的映射,将第一SIP响应消息发送至位于外部网络的终端93。
位于外部网络的终端93收到第一SIP响应消息,将通过第一socket发送数据信息至代理服务器91,代理服务器91通过媒体流代理模块将数据信息发送至内网服务器92,从而完成内外网的通讯。
并且内网服务器92可以周期性的向代理服务器91发送ProxyHearbeat消息,维护两者之间的连接,ProxyHearbeat消息机制为现有技术在此不再赘述,会话初始协议代理模块向会话初始协议服务模块主动连接,即主动发送第二SIP请求消息完成两者之间的连接。
本发明实施例通过代理服务器91完成内网服务器92与位于外部网络的终端93之间的通讯,而位于内部网络的终端与位于外部网络的终端93进行多媒体会议时,位于内部网络的终端与内网服务器92完成数据的交互为现有技术在此不再赘述,本发明通过上述方法完成位于外部网络的终端93与内网服务器92之间进行数据的交互,从而实现了位于内部网络的终端与位于外部网络的终端93在内网服务器的参与下完成多媒体会议。
本发明实施例提供了一种基于内外网的数据通讯系统,通过接收位于外部网络的终端通过第一socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;接收所述内网服务器发送的socket配对请求消息,生成所述第一socket和所述第二socket之间的映射;接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。由于本发明实施例通过代理服务器完成内网服务器与位于外部网络的终端之间的通讯,无需人工在出口路由器上配置内网服务器的某个端口与外部网络的某个端口的映射,解决了路由器选择的限制以及在拨号网络环境下重新配置出口路由器的问题,并且保证了内外网的准确通讯。
对于系统/装置实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
本领域内的技术人员应明白,本申请的实施例可提供为方法、系统、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本申请是参照根据本申请实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
尽管已描述了本申请的优选实施例,但本领域内的技术人员一旦得知了基本创造性概念,则可对这些实施例做出另外的变更和修改。所以,所附权利要求意欲解释为包括优选实施例以及落入本申请范围的所有变更和修改。
显然,本领域的技术人员可以对本发明进行各种改动和变型而不脱离本发明的精神和范围。这样,倘若本发明的这些修改和变型属于本发明权利要求及其等同技术的范围之内,则本发明也意图包含这些改动和变型在内。
Claims (23)
1.一种基于内外网的数据通讯方法,其特征在于,所述方法包括:
接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;
接收所述内网服务器发送的socket配对请求消息,生成所述第一socket和所述第二socket之间的映射;
接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
2.如权利要求1所述的方法,其特征在于,在所述接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息之前,所述方法还包括:
接收所述终端发送的基础会议GetConferenceBasic请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;
将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;
接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;
将所述GetConferenceBasic响应消息转发至所述终端;
所述接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息包括:
所述IP地址的代理服务器通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
3.如权利要求2所述的方法,其特征在于,在所述接收所述终端发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
接收所述内网服务器发送的第二SIP请求消息,将传输所述第二SIP请求消息的第二传输控制协议TCP socket保存为SIPS socket;
所述将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器包括:
将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPSsocket转发至所述内网服务器。
4.如权利要求1所述的方法,其特征在于,在所述接收内网服务器通过第二socket发送的第二数据传输请求消息之前,所述方法还包括:
接收所述终端发送的第一会话初始协议SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
5.如权利要求4所述的方法,其特征在于,所述将所述第一SIP请求消息转发至内网服务器,包括:
将所述第一SIP请求消息中的联络地址信息替换为所述代理服务器的IP地址;
将地址替换后的第一SIP请求消息转发至所述内网服务器。
6.如权利要求4所述的方法,其特征在于,在将所述第一SIP请求消息转发至内网服务器之前,所述方法还包括:
解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;
根据所述源端的标识信息以及发送所述第一SIP请求消息的第一传输控制协议套接字TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
7.如权利要求6所述的方法,其特征在于,在所述将所述第一SIP请求消息转发至内网服务器之后,所述方法还包括:
接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;
根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCP socket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
8.一种基于内外网的数据通讯方法,其特征在于,所述方法包括:
通过第二套接字socket向代理服务器发送第二数据传输请求消息;
向所述代理服务器发送套接字socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket;
接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
9.如权利要求8所述的方法,其特征在于,在所述通过第二套接字socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:
接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;
解析所述GetConferenceBasic请求消息;
若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;
将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;
所述通过第二socket向所述代理服务器发送第二数据传输请求消息包括:
根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
10.如权利要求9所述的方法,其特征在于,在所述接收所述代理服务器发送的基础会议GetConferenceBasic请求消息之前,所述方法还包括:
发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPS socket,并采用保存的所述SIPS socket转发所述GetConferenceBasic请求消息。
11.如权利要求8所述的方法,其特征在于,在所述通过第二套接字socket向代理服务器发送第二数据传输请求消息之前,所述方法还包括:
接收第一会话初始协议SIP请求消息;
解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;
若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送套接字socket配对请求消息。
12.一种基于内外网的数据通讯装置,其特征在于,所述装置包括:
媒体流代理模块,用于接收位于外部网络的终端通过第一套接字socket发送的第一数据传输请求消息;并接收内网服务器通过第二socket发送的第二数据传输请求消息;
代理服务模块,用于接收所述内网服务器发送的socket配对请求消息;
所述媒体流代理模块,还用于生成所述第一socket和所述第二socket之间的映射;接收所述终端通过所述第一socket传输的数据信息,根据所述第一socket与所述第二socket的映射,将所述数据信息通过所述第二socket发送至内网服务器。
13.如权利要求12所述的装置,其特征在于,所述装置还包括:会话初始协议代理模块,用于接收所述终端发送的基础会议GetConferenceBasic请求消息,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址信息替换后的所述GetConferenceBasic请求消息转发至所述内网服务器;接收所述内网服务器发送的GetConferenceBasic响应消息,其中所述GetConferenceBasic响应消息中携带所述代理服务器的IP地址及其数据端口号,所述代理服务器的IP地址及其数据端口号为所述内网服务器根据保存的代理服务器与其IP地址、数据端口号的对应关系,在接收到所述代理服务器发送的GetConferenceBasic请求消息后确定的;将所述GetConferenceBasic响应消息转发至所述终端;所述媒体流代理模块,具体用于通过所述数据端口号接收所述终端发送的所述第一数据传输请求消息。
14.如权利要求13所述的装置,其特征在于,所述会话初始协议代理模块,还用于接收所述内网服务器发送的第二SIP请求消息,将传输所述第二SIP请求消息的第二传输控制协议TCP socket保存为SIPS socket;将地址信息替换后的所述GetConferenceBasic请求消息通过所述SIPS socket转发至所述内网服务器。
15.如权利要求13所述的装置,其特征在于,所述会话初始协议代理模块,还用于接收所述终端发送的第一会话初始协议SIP请求消息,将所述第一SIP请求消息转发至内网服务器。
16.如权利要求15所述的方法,其特征在于,所述会话初始协议代理模块,具体用于将所述第一SIP请求消息中的联络地址信息替换为所述代理服务器的IP地址;将地址替换后的第一SIP请求消息转发至所述内网服务器。
17.如权利要求15所述的装置,其特征在于,所述会话初始协议代理模块,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中携带的源端的标识信息;根据所述源端的标识信息以及发送所述第一SIP请求消息的第一传输控制协议套接字TCP socket,建立所述源端的标识信息与所述第一TCP socket的映射。
18.如权利要求17所述的装置,其特征在于,所述会话初始协议代理模块,还用于接收并解析所述内网服务器发送的所述第一SIP响应消息,识别所述第一SIP响应消息中携带的源端的标识信息;根据所述源端的标识信息与所述第一TCP socket的映射,将所述第一SIP响应消息通过第一TCP socket转发至所述终端,所述数据信息为所述终端接收到所述代理服务器发送的第一SIP响应消息之后发送的。
19.一种基于内外网的数据通讯装置,其特征在于,所述装置包括:
媒体流服务模块,通过第二套接字socket向代理服务器发送第二数据传输请求消息;
内网服务模块,还用于向所述代理服务器发送套接字socket配对请求消息,以使所述代理服务器生成第一socket和第二socket之间的映射,其中所述第一socket为位于外部网络的终端向所述代理服务器发送第一数据传输请求消息的socket;
所述媒体流服务模块,还用于接收所述代理服务器通过所述第二socket传输的数据信息,其中所述数据信息由所述终端通过所述第一socket传输至所述代理服务器,所述代理服务器根据所述第一socket与第二socket的映射,通过所述第二socket传输至内网服务器。
20.如权利要求19所述的装置,其特征在于,所述装置还包括:会话初始协议服务模块,用于接收所述代理服务器发送的基础会议GetConferenceBasic请求消息,其中所述GetConferenceBasic请求消息为所述代理服务器接收到所述终端发送的GetConferenceBasic请求消息后,将所述GetConferenceBasic请求消息中的联络地址信息替换为所述代理服务器的IP地址后发送的;解析所述GetConferenceBasic请求消息;若所述GetConferenceBasic请求消息中联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,根据保存的代理服务器的IP地址及其数据端口号的对应关系,确定所述IP地址的代理服务器对应的数据端口号;将所述IP地址及确定的所述数据端口号携带在GetConferenceBasic响应消息中发送给所述代理服务器;所述媒体流服务模块,具体用于根据所述数据端口号向所述IP地址的代理服务器发送第二数据传输请求消息。
21.如权利要求20所述的装置,其特征在于,所述会话初始协议服务模块,还用于发送第二SIP请求消息至所述代理服务器,以使所述代理服务器将传输所述第二SIP请求消息的传输控制协议TCP socket保存为SIPS socket,并采用保存的所述SIPS socket转发所述GetConferenceBasic请求消息。
22.如权利要求19所述的装置,其特征在于,所述会话初始协议服务模块,还用于接收第一会话初始协议SIP请求消息;所述内网服务模块,还用于解析所述第一SIP请求消息,获取所述第一SIP请求消息中的联络地址信息;若解析得到的所述联络地址信息与所述内网服务器中预存的代理服务器的IP地址相同,向所述代理服务器发送套接字socket配对请求消息。
23.一种基于内外网的数据通讯系统,其特征在于,包括上述权利要求12-18任一项所述的应用于代理服务器的基于内外网的数据通讯装置,上述权利要求19-22任一项所述的应用于内网服务器的基于内外网的数据通讯装置,以及与所述内网服务器进行数据通讯的位于外部网络的终端。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710547352.2A CN107257345B (zh) | 2017-07-06 | 2017-07-06 | 一种基于内外网的数据通讯方法、装置及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710547352.2A CN107257345B (zh) | 2017-07-06 | 2017-07-06 | 一种基于内外网的数据通讯方法、装置及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107257345A true CN107257345A (zh) | 2017-10-17 |
CN107257345B CN107257345B (zh) | 2019-12-24 |
Family
ID=60025414
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710547352.2A Active CN107257345B (zh) | 2017-07-06 | 2017-07-06 | 一种基于内外网的数据通讯方法、装置及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107257345B (zh) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107995321A (zh) * | 2017-11-17 | 2018-05-04 | 杭州迪普科技股份有限公司 | 一种vpn客户端代理dns的方法及装置 |
CN108200170A (zh) * | 2018-01-02 | 2018-06-22 | 武汉斗鱼网络科技有限公司 | 消息处理方法、装置及可读存储介质 |
CN109194637A (zh) * | 2018-08-23 | 2019-01-11 | 深圳点猫科技有限公司 | 一种用于教育云平台的内外网通讯方法及系统 |
CN109194728A (zh) * | 2018-08-16 | 2019-01-11 | 常熟市顺网网络技术服务有限公司 | 一种可实现内外网文件共享的系统及方法 |
CN109962962A (zh) * | 2017-12-26 | 2019-07-02 | 航天信息股份有限公司 | 一种套接字socket连接的方法及设备 |
CN110262993A (zh) * | 2019-06-11 | 2019-09-20 | 浙江华创视讯科技有限公司 | 输入信息的读取方法及电路、存储介质、电子装置 |
CN110278181A (zh) * | 2019-01-29 | 2019-09-24 | 广州金越软件技术有限公司 | 一种关于跨网数据交换的即时协议转换技术 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103023789A (zh) * | 2012-12-05 | 2013-04-03 | 北方工业大学 | 因特网中访问私网服务器的方法 |
CN103888511A (zh) * | 2014-02-20 | 2014-06-25 | 北京哈工大计算机网络与信息安全技术研究中心 | 一种基于动态代理的远程访问控制方法 |
-
2017
- 2017-07-06 CN CN201710547352.2A patent/CN107257345B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103023789A (zh) * | 2012-12-05 | 2013-04-03 | 北方工业大学 | 因特网中访问私网服务器的方法 |
CN103888511A (zh) * | 2014-02-20 | 2014-06-25 | 北京哈工大计算机网络与信息安全技术研究中心 | 一种基于动态代理的远程访问控制方法 |
Cited By (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107995321A (zh) * | 2017-11-17 | 2018-05-04 | 杭州迪普科技股份有限公司 | 一种vpn客户端代理dns的方法及装置 |
CN109962962A (zh) * | 2017-12-26 | 2019-07-02 | 航天信息股份有限公司 | 一种套接字socket连接的方法及设备 |
CN109962962B (zh) * | 2017-12-26 | 2022-04-26 | 航天信息股份有限公司 | 一种套接字socket连接的方法及设备 |
CN108200170A (zh) * | 2018-01-02 | 2018-06-22 | 武汉斗鱼网络科技有限公司 | 消息处理方法、装置及可读存储介质 |
WO2019134306A1 (zh) * | 2018-01-02 | 2019-07-11 | 武汉斗鱼网络科技有限公司 | 消息处理方法、装置、终端设备及可读存储介质 |
CN108200170B (zh) * | 2018-01-02 | 2020-01-03 | 武汉斗鱼网络科技有限公司 | 消息处理方法、装置及可读存储介质 |
CN109194728A (zh) * | 2018-08-16 | 2019-01-11 | 常熟市顺网网络技术服务有限公司 | 一种可实现内外网文件共享的系统及方法 |
CN109194637A (zh) * | 2018-08-23 | 2019-01-11 | 深圳点猫科技有限公司 | 一种用于教育云平台的内外网通讯方法及系统 |
CN110278181A (zh) * | 2019-01-29 | 2019-09-24 | 广州金越软件技术有限公司 | 一种关于跨网数据交换的即时协议转换技术 |
CN110278181B (zh) * | 2019-01-29 | 2021-09-17 | 广州金越软件技术有限公司 | 一种关于跨网数据交换的即时协议转换系统 |
CN110262993A (zh) * | 2019-06-11 | 2019-09-20 | 浙江华创视讯科技有限公司 | 输入信息的读取方法及电路、存储介质、电子装置 |
Also Published As
Publication number | Publication date |
---|---|
CN107257345B (zh) | 2019-12-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107257345A (zh) | 一种基于内外网的数据通讯方法、装置及系统 | |
US9497168B2 (en) | Method and apparatus for supporting communications between a computing device within a network and an external computing device | |
EP2220852B1 (en) | Communicating a selection of a potential configuration | |
US7043564B1 (en) | Methods and apparatus for managing network traffic using network address translation | |
US9148333B2 (en) | System and method for providing anonymity in a session initiated protocol network | |
CN100527750C (zh) | 可经由网络地址转换型设备操作的通信方法 | |
US20100283827A1 (en) | System and method for providing anonymity in a video/multimedia communications session over a network | |
JP5629086B2 (ja) | 同一ipポートを使用するアプリケーションの複数のインスタンス間で、受信したセッションを送信するための方法およびシステム | |
US9998543B2 (en) | Remote monitoring of user appliances | |
US20060168321A1 (en) | System and method for traversing firewalls, NATs, and proxies with rich media communications and other application protocols | |
WO2002003217A1 (en) | System, method, and computer program product for resolving addressing in a network including a network address translator | |
KR101981812B1 (ko) | 네트워크 통신 시스템들 및 방법들 | |
US10244011B2 (en) | Multiplexing sessions in telecommunications equipment using interactive connectivity establishment | |
EP2226987A1 (en) | Terminal device, system, connection management server, and computer program for establishing direct communication between terminals | |
CN109196842B (zh) | 一种会话保持方法、设备及存储介质 | |
EP2911432B1 (en) | Sip based inter-mtc device secure communications method, device, and system | |
US9380078B2 (en) | Method and system to add video capability to any voice over internet protocol (Vo/IP) session initiation protocol (SIP) phone | |
CN111343083B (zh) | 即时通信方法、装置、电子设备及可读存储介质 | |
CN111464879A (zh) | 一种数据通信的方法及装置 | |
NO341143B1 (no) | Samvirking | |
KR20140092630A (ko) | 사용자장치, 통신서버 및 그 제어방법 | |
US11172000B2 (en) | Methods and apparatus for facilitating real time multimedia communications | |
CN108156150A (zh) | 一种数据传输方法及装置 | |
US11997074B1 (en) | Obscuring participants in a videoconference | |
US20070263073A1 (en) | System and method for identifying the reachability status of ip and sip based videoconferencing systems |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |