BACKGROUND
1. Technical Field
The present invention relates to a system and method for media communication through Network Address Translation.
2. Description of Related Art
Network Address Translation (NAT) refers to a function of translating an IP address when an IP packet is forwarded through a router. In a private network, a private address identified only in the private network is used. For an IP packet forwarded to a public network (a network positioned outside the private network), the NAT translates a private address of the IP packet into a public address, which is unique on the Internet.
A media packet generated from a caller IP terminal (an IP terminal located in a private network) and forwarded to the public network, has its private transmission address replaced by a public address, which is dynamically assigned from the available public addresses through the NAT. A callee IP terminal (an IP terminal located in the public network) can receive the media packet from the caller. However, when the callee tries to return a media packet to the caller, the callee fails because the caller cannot receive the media packet because the addresses of the caller are not routable in the NAT private network. Thus, a call between two IP terminals is not established.
What is needed, therefore, is a system and method for media communication to overcome the above-described shortcoming.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of an embodiment of a media communication system through NAT;
FIG. 2 is a block diagram of a construction of a signaling channel connected between a caller IP terminal and a callee IP terminal; and
FIG. 3 is a block diagram of a construction of relaying media packets between a caller IP terminal and a callee IP terminal through a media relay server.
DETAILED DESCRIPTION OF THE EMBODIMENT
Referring to FIG. 1, a system for media communication includes a caller IP terminal 10, a first NAT router 20 corresponding to the caller IP terminal 10, a media relay server 30, a soft switch device 40, a callee IP terminal 60, and a second NAT router 50 corresponding to the callee IP terminal 60. The caller IP terminal 10 and the callee IP terminal 60 construct a connection among different NAT routers through the media relay server 30 and the soft switch device 40.
FIG. 2 illustrates a construction of a signaling channel for generating a call between the caller IP terminal 10 and the callee IP terminal 60. The caller IP terminal 10 and the callee IP terminal 60 establish an IP channel with the soft switch device 40, and send identification (ID) to the soft switch device 40. The soft switch device 40 saves the IP channel information (IP addresses and ports) and users' IDs. When the caller IP terminal 10 calls the soft switch device 40, the soft switch device 40 finds the callee IP terminal 60 through the IP channel. If the callee IP terminal 60 is positioned in some other NAT private network, the soft switch device 40 saves signaling messages from the caller IP terminal 10. The soft switch device 40 obtains the IP channel of the callee IP terminal 60 from the stored IP channel information, and then transmits a call request to the callee IP terminal 60. The callee IP terminal 60 receives the call request and establishes a signaling channel with the soft switch device 40.
FIG. 3 illustrates a media packet penetrating the NAT private network between the caller IP terminal 10 and the callee IP terminal 60. When the call is generated by the caller IP terminal 10, the soft switch device 40 checks whether a relay service is needed according to configuration data (the caller IP terminal 10 sending configuration data to the soft switch device 40). The soft switch device 40 assigns a relay port and sends a relay port command to the media relay server 30. The media relay server 30 employs the relay port for media packet relay between the caller IP terminal 10 and the callee IP terminal 60. Then, the soft switch device 40 amends the signaling messages of the caller IP terminal 10 and the callee IP terminal 60 so that the media packets of the caller IP terminal 10 and the callee IP terminal 60 are transmitted to the media relay server 30. The media relay server 30 receives the media packets on the relay port, records the IP addresses of the caller IP terminal 10 and the callee IP terminal 60, and establishes a corresponding connection between the caller IP terminal 10 and the callee IP terminal 60. When the media relay server 30 receives the media packet, the media relay server 30 compares the IP address of the media packet with the stored IP addresses and sends the media packet to the appropriate IP address. The media packets may be encrypted.
FIG. 4 illustrates a flow chart of FIG. 3. Depending on the embodiment, certain of the steps described below may be removed, others may be added, and the sequence of steps may be altered.
- Step 400: the soft switch device 40 assigns a relay port and sends a command to the media relay server 30 to employ the relay port.
- Step 410: the soft switch device 40 amends signaling messages from the caller IP terminal 10 and the callee IP terminal 60 so that media packets from the caller IP terminal 10 and the callee IP terminal 60 are transmitted to the media relay server 30.
- Step 420: the media relay server 30 receives the media packets on the relay port, records IP addresses, and establishes a corresponding connection between the caller IP terminal 10 and the callee IP terminal 60 for relaying the media packets.
It is to be understood, however, that even though numerous characteristics and advantages of the embodiments have been set forth in the foregoing description, together with details of the structure and function of the embodiments, the disclosure is illustrative only, and changes may be made in detail, especially in matters of shape, size, and arrangement of parts within the principles of the invention to the full extent indicated by the broad general meaning of the terms in which the appended claims are expressed.