The present invention relates generally to a secure access to a private LAN, and more particularly to a dynamic tunnel construction method for securely accessing to the private LAN and apparatus therefor.
As an IP address resource will be becoming extremely rich in a future Ipv6 environment, with various kinds of electronic devices intelligentized and formed into networks, each device within a private LAN (such as intranet, home-network or the like) will become possible to own an independent IP address, through which or a domain name corresponding the IP address the respective devices may be addressed from an external network. This will make it possible in technique to remotely access to and control the devices within the private LAN via Internet. As applications and services are developing, it will become gradually an imminent need for those subscribers to perform a remote access to and control of the devices within the private LAN.
However, the owners of the devices do not like to let their devices within the private LAN to be optionally accessed to from the external network due to consideration of the privacy and sensitivity of the devices within the private LAN. If the external network is permitted to optionally access to those devices, the devices will suffer a huge risk of being attacked, which may lead to a severe damage upon the owners of the devices.
A tunnel technique is a scheme widely used at the present to solve the above secure access problems that occur in access to the private LAN. In this scheme, the authenticated subscribers in the external network may legally access to the devices within the private LAN via a secure communication tunnel established between the private LAN and the external network, while the other hosts/devices which do not pass authentication in the external network cannot access to the private LAN.
In prior art, various kinds of tunnel technique based Virtual Private Network (VPN) technologies belong presently to a relatively perfect mechanism for securely accessing to the private network. In VPN technologies, there has been provided for the subscribers a virtual private network, which has a similar security to those private networks formed of private physics lines that are rented by the subscribers while conducting a communication by means of fundamental facilities of public networks. With the tunnel technique, the VPN enables legal subscribers having been passed identity authentication to access to LANs within the VPN from the external network, and prevents the other hosts/devices which do not pass authentication in the external network from accessing to these LANs. Moreover, the communications between the external network and the VPN LANs have security and privacy.
(1) Remote Access Mode
In the remote access mode, the secure communication tunnel is often fixedly configured, that is, a secure tunnel is manually configured by a manager of the private LAN (VPN) in advance between a local point of presence and a remote access server. Here the remote access server and the local point of presence are referred to as tunnel server. When a certain source host within the external network needs to access to the private LAN (VPN), it is first connected to the local point of presence (POP), and then issues an access request for a remote access server to be accessed to in the private LAN. Upon an identity authentication having been passed, the source host within the external network becomes possible to access to the private LAN in distance via the secure tunnel established in advance.
The main shortages of the remote access mode lie in that: the secure tunnel is manually configured, so a lot of manually configuring jobs are required for VPN managers. Moreover, when networking components vary in the private LAN (VPN), for example, IP address is modified for the present remote access server/local point of presence, or a new remote access server/local point of presence is configured, etc., such statically configured manual tunnels need to be manually modified, which will become complicated.
(2) Local Access Mode
In the local access mode, when a source host within the external network is about to access to the private LAN (VPN), it is first directly connected to a local access server to be accessed to in a local private LAN. In other words, the source host within the external network needs to be aware of an IP address of a corresponding local access server. Upon an identity authentication having been passed, a secure communication tunnel is established through negotiation between the local access server and the source host within the external network. Thereafter, the source host within the external network becomes possible to access to the private LAN in local via the tunnel. In such a mode, the roles of the tunnel servers are played by the local access servers and the source hosts within the external network.
The main shortages of the local access mode lie in that: the tunnel is not transparent with respect to the subscribers. In other words, when a secure communication tunnel is to be established to access to a certain private LAN (VPN) from the external network, the subscribers are required to provide an IP address for the access servers with respect to corresponding private LANs. In order to access to various private LANs, the subscribers need to keep in memory a lot of addresses for the access servers, which will increase the burden and difficulty of the subscribers using VPN.
In addition, neither of the above two kinds of tunnel establishment methods supports subscriber devices of a small scale. All the hosts in the external network that are used to access to the private LANs participate in establishment procedures of secure communication tunnels to different extents. Especially for the local access mode, the hosts within the external network serve as tunnel servers to be directly in charge of the negotiation and establishment of the secure communication tunnels, which requires those hosts to install therein a tunnel support software that is complicated. In several circumstances, however, the devices that the subscribers use to access to the private LANs are likely to be quite simple in hardware and software, without such a tunnel support software installed or installable therein. As a result, the devices that the subscribers use to access to the private LANs will not be able to access to the private LANs via the secure tunnels.
The present invention provides a dynamic tunnel establishment method that is novel. In the method of the present invention, a source tunnel server or a destination tunnel server is disposed on a routing device through which a source host transmits IP data packets or a routing device through which a destination host receives IP data packets. Subsequently, a secure communication tunnel is established automatically rather than manually between the source and destination tunnel servers, without requiring any IP address to be provided for the access servers with respect to corresponding private LANs.
The method of the present invention comprises the following steps:
Firstly, a source host within an external network transmits subscriber identity authentication information to a party to which an identity authenticating unit pertains so as to perform an identity authentication at the party to which the identity authenticating unit pertains. Wherein the subscriber identity authentication information includes subscriber name, subscriber password, IP address and port number of the destination host, and IP address of the source host. The IP address of the source host may be a default value indicating an external network host itself having originated an access to the private LAN.
Secondly, upon the identity authentication having been passed, the party to which the identity authenticating unit pertains generates an IP data packet containing a secure communication tunnel establishment command. Wherein the IP data packet is subjected to encryption and subsequent transmission to a device on a side of a destination host within the private LAN, the device is disposed on a path through which the destination host receives/transmits IP data packets. The contents of the IP data packet containing the secure communication tunnel establishment command include IP address of the source host, IP address and port number of the destination host, and preserved parameters for establishing the secure communication tunnel. The destination address of the IP data packet is IP addresses of the destination host.
Thirdly, the device on the side of the destination host intercepts and de-encrypts the IP data packet containing the secure communication tunnel establishment command, and then generates an IP data packet containing a tunnel negotiation command, which is subjected to encryption and subsequent transmission to a device on a side of the source host within the external network, the device is disposed on a path through which the source host receives/transmits IP data packets. The destination address of the IP data packet is IP address of the source host.
Thereafter, the device on the side of the source host intercepts and de-encrypts the IP data packet containing the tunnel negotiation command, and then generates an IP data packet containing a tunnel negotiation response command, which is subjected to encryption and subsequently transmitted to the device on the side of the destination host; and
Finally, the device on the side of the destination host intercepts and de-encrypts the IP data packet containing the tunnel negotiation response command. The device on the side of the destination host negotiates with the device on the side of the source host to establish a secure communication tunnel in accordance with tunnel parameters within the tunnel negotiation command.
The device on the side of the above source host performing interception, de-encryption, generation, encryption and transmission of the IP data packets is a source tunnel server disposed on the path through which the source host receives/transmits IP data packets.
The device on the side of the above destination host performing interception, de-encryption, generation, encryption and transmission of the IP data packets is a destination tunnel server disposed on the path through which the destination host receives/transmits IP data packets.
The present invention also provides a tunnel server, wherein the tunnel server is either disposed on a path through which a source host within an external network receives/transmits IP data packets, to serve as a source tunnel server, or on a path through which a destination host within a private LAN receives/transmits IP data packets, to serve as a destination tunnel server, comprising:
a tunnel negotiating unit being configured to negotiate with a tunnel server at an opposite end about encryption/de-encryption parameters of tunnel in accordance with corresponding instruction;
a tunnel data packet processing unit being configured to perform an encrypting/ a de-encrypting process of the IP data packets transmitted via secure communication tunnel in accordance with the encryption/de-encryption parameters of tunnel;
a security policy & security union database further including a security policy database for storing various kinds of security policies and a security union database for storing various kinds of security unions,
a tunnel command filtering unit being configured to intercept the IP data packet containing tunnel command from the external network;
a tunnel command processing unit being configured to perform a de-encryption of the IP data packet containing tunnel command intercepted by the tunnel command filtering unit, and to issue corresponding instruction in accordance with contents of the tunnel command; and
a tunnel command generating unit being configured to generate corresponding tunnel command in accordance with the instruction from the tunnel command processing unit, and to encrypt and transmit the tunnel command to a destination address.
With the dynamic tunnel establishment method of the present invention, the following contributions are made against the prior art:
1. Automation:it is possible to dynamically and automatically establish the secure communication tunnel without any manual intervention, there is no influence to the dynamic tunnel establishment method in spite of networking components having changed.
2. Facilitation: the secure tunnel is transparent with respect to the subscribers, who therefore need not keep in memory any addresses of tunnel servers, which leads the use of the subscribers easier.
3. Support for Simple Hosts: the establishment of the secure communication tunnel in the present method is fully accomplished by the devices (including AAA servers, tunnel servers or the like) of network service provider (NSP). Except for providing identity authentication information, the source hosts within the external network need no configuration and process in relation to the negotiation and establishment of the secure communication tunnels. Therefore, there is no need to install those support software and hardware in relation to the negotiation and establishment of the secure communication tunnels. With the present method, those hosts relatively simply in software and hardware are also able to dynamically establish the secure communication tunnels for accessing to the private LANs.
The other objectives and advantages of the present invention would become apparent, and the present invention would be more fully understood from the description given below in conjunction with the drawings as well as claims.
The present invention and the advantages thereof will be further described by means of exemplary embodiments and the accompanying drawings:
The present invention will be further described below in detail with reference to the preferred embodiments and the drawings.
The source host within the external network transmits subscriber identity authentication information to the server to which the identity authenticating unit pertains, so as to perform the identity authentication at the identity authenticating unit (step 320). The subscriber identity authentication information includes subscriber name, subscriber password, IP address and port number of the destination host, and IP address of the source host.
The step of the identity authenticating unit performing the identity authentication of the received identity authentication information further comprises the following steps:
The identity authenticating unit acquires a network address range of the private LANs corresponding to the subscriber names from an AAA server within a public network in accordance with the received information, and
checks whether or not the subscriber name and password belongs to legal subscriber of the private LAN and whether or not the destination host to be subjected to access to belongs to the private LAN.
If the identity authenticating unit has checked the subscriber being one of legal subscribers, the server to which the identity authenticating unit pertains generates an IP data packet containing a secure communication tunnel establishment command. The IP data packet is subjected to encryption and subsequent transmission to the destination tunnel server (step 330). The contents of the IP data packet containing the secure communication tunnel establishment command include IP address of the source hosts, IP address and port number of the destination host, and preserved parameters for establishing the secure communication tunnel. The destination address of the IP data packet is IP address of the destination host. The IP address of the source host may be a default value indicating an external network host itself having originated an access to said private LAN.
The destination tunnel server intercepts and processes the IP data packet containing the secure communication tunnel establishment command (step 340). The destination tunnel server intercepts the IP data packet containing tunnel commands in accordance with the methods derived from in-advance negotiations, and performs a de-encryption of the IP data packet, subsequently issues corresponding instruction in accordance with the contents of the tunnel command. Since the tunnel command described herein is to establish the secure communication tunnel, the destination tunnel server generates, in accordance with the instruction, an IP data packet containing a tunnel negotiation command, which is subjected to encryption and subsequently transmitted to the source tunnel server. The destination address of the IP data packet is IP address of the source host.
The source tunnel server intercepts and processes the IP data packet containing the tunnel negotiation command (step 350). The source tunnel server intercepts the IP data packet containing the tunnel negotiation command in accordance with the methods derived from in-advance negotiations. The contents of the IP data packet containing the tunnel negotiation command include IP address of the source host, IP address and port number of the destination host, and parameters regarding the secure communication tunnel. The source tunnel server then performs a de-encryption of the IP data packet, and issues corresponding instruction in accordance with the contents of the tunnel command. Since the tunnel command described herein is to negotiate with respect to the secure communication tunnel, the source tunnel server generates, in accordance with the instruction, an IP data packet containing a tunnel negotiation response command, which is subjected to encryption and subsequent transmission to the destination tunnel server.
The destination tunnel server intercepts and processes the IP data packet containing the tunnel negotiation response command (step 360). The destination tunnel server intercepts the IP data packet containing the tunnel command in accordance with the method derived from in-advance negotiations, and performs a de-encryption of the IP data packet, subsequently issues corresponding instruction in accordance with the contents of the tunnel command. Since the tunnel command described herein is the tunnel negotiation response command, when the tunnel command processing unit has determined it being accurate response command in accordance with the corresponding instruction, the tunnel negotiating module is called to enable the destination tunnel server to negotiate with the source tunnel server in accordance with the tunnel parameters within the tunnel negotiation command thereby to establish the secure communication tunnel.
During the aforesaid procedure of establishing the secure communication tunnel, the destination tunnel server, the source tunnel server, or the server to which the identity authenticating unit pertains intercepts the IP data packet containing the tunnel command in accordance with the method derived from in-advance negotiations. The method may be flexibly designed. There rise two instances.
For example, it is possible to perform such an interception in accordance with Security Parameter Index (SPI) within header of said IP data packet. As for the Security Parameter Index, a stipulated reserved Security Parameter Index is placed into the header of the IP data packet as the Security Parameter Index (SPI) of the IP data packet, after encrypting the IP data packets containing tunnel commands at the party to which the identity authenticating unit pertains, a device on a side of the source host or a device on a side of the destination host.
As another example, it is possible to perform such an interception in accordance with the source address within the IP data packet. As for the source address, a stipulated reserved address is used as the source address of the IP data packet, after encrypting the IP data packet containing tunnel command at the party to which the identity authenticating unit pertains, a device on a side of the source host or a device on a side of the destination host.
During the aforesaid procedure of establishing the secure communication tunnel, the IP data packet is encrypted or de-encrypted, at the source tunnel server, the destination tunnel server, and the server to which the identity authenticating unit pertains, in accordance with security policies derived from their negotiation with each other and security unions corresponding to the security policies. The security policies and security unions are respectively stored in a security policy database and security union database that are those of the prior art.
As soon as a secure communication tunnel has been established between the source tunnel server and destination tunnel server, the source host within the external network becomes able to access to the destination host within the private LAN via the secure communication tunnel.
When it has been finished for the source host within the external network to access to the private LAN via the secure communication tunnel, the secure communication tunnel may be canceled (step 370). In specific, this includes the following steps: the source host within the external network transmits the subscriber identity authentication information to the server to which the identity authenticating unit pertains. Thereafter, the server to which the identity authenticating unit pertains perform an identity authentication of the received information, upon having been subjected to the identity authentication, transmits an encrypted IP data packet containing a secure communication tunnel cancellation command to the destination tunnel server, wherein the destination addresses of the IP data packets are IP addresses of the destination hosts. Finally, the destination tunnel server issues a notification of canceling the secure communication tunnel to the source tunnel server, and deletes tunnel parameters within the destination tunnel server.
In the present embodiment, the identity authenticating unit is independently disposed on the server such as AAA server within the public network. However, it should be appreciated by the skilled in the art that the identity authenticating unit is allowed to have quite flexible dispositions, it can be either independently disposed on the other devices within the public network, or disposed on the destination tunnel server or the source tunnel server.
The tunnel server is disposed on a path through which a source host within the external network receives/transmits data packets, to serve as a source tunnel server, or on a path through which a destination host within the private LAN receives/transmits data packets, to serve as a destination tunnel server. Thus, a secure communication tunnel can be dynamically established between the source tunnel server and the destination tunnel server, and used to securely access to the private LAN.
A tunnel server 400 comprises a tunnel negotiating unit 410, a tunnel data packet processing unit 420, a database 430, a tunnel command filtering unit 440, a tunnel command processing unit 450, and a tunnel command generating unit 460. Among the above units, the tunnel negotiating unit 410, the tunnel data packet processing unit 420, and the database 430 are normal modules of the tunnel server that belong to the prior art. However, the tunnel command filtering unit 440, the tunnel command processing unit 450, and the tunnel command generating unit 460 are newly added modules in the present invention. With these newly added modules, a secure communication tunnel can be dynamically established between the source tunnel server and the destination tunnel server, without any participation of the devices of the subscribers. Thus the tunnel server addressing the network can be automatically completed without any manual configuration of the address information of the tunnel server.
The tunnel negotiating unit 410 is used to negotiate with a tunnel server at an opposite end, with respect to encryption/de-encryption parameters of tunnels, in accordance with corresponding instructions. The tunnel negotiating unit 410 is normal model of tunnel server. “a tunnel server at an opposite end” described herein is in relation to the tunnel server 400. If the tunnel server 400 is a source tunnel server, the tunnel server at the opposite end is a destination tunnel server, vice versa.
The tunnel data packet processing unit 420 is used to perform an encryption/de-encryption process of data packets transmitted via the secure communication tunnel in accordance with the encryption/de-encryption parameters of tunnels. The tunnel data packet processing unit 420 is a normal module of the tunnel server.
The database 430 includes a security policy database for storing various kinds of security policies and a security union database for storing various kinds of security unions. The database 430 is a normal module of the tunnel server.
The security policy (SP) and security union (SA) belong to a convention set up between two communication entities, for example, the source host within the external network and the destination host within the private LAN, for purposes of secure communications. Among them, the security policy is intended to determine whether outgoing or incoming IP data packet needs security assurances and protections, includes at least two optional symbols of the source and destination addresses of the IP data packets. In addition, the security policy further includes the other optional symbols of the source and destination ports or the like. Various kinds of security policies may be stored in the security policy database. The security union is intended to determine IPSec protocols, encryption manners, secret keys, and effective duration of the secret keys or the like for the security assurances and protections of the IP data packets. Similarly, various kinds of security union may be stored in the security union database. The correspondence between the security policy and the security union belongs to the prior art.
The tunnel command filtering unit 440 is used to intercept the IP data packet containing tunnel commands from the external network. There may be a plurality of flexible approaches for the tunnel command filtering unit 440 to intercept the IP data packet containing tunnel commands. For the details, refer to the description of the first embodiment. Such details are no longer repeated for the present embodiment.
The tunnel command processing unit 450 is used to perform a de-encryption of the IP data packet containing the tunnel commands that is intercepted by the tunnel command filtering unit, and to issue corresponding instructions to the tunnel negotiating unit 410 or the tunnel command generating unit 460 in accordance with the contents of the tunnel commands. If the tunnel command is a secure communication tunnel establishment command, the tunnel command processing unit 450 issues an instruction to the tunnel command generating unit 460 to generate and transmit a secure communication tunnel negotiation command. If the tunnel command is a secure communication tunnel negotiation command, the tunnel command processing unit 450 issues an instruction to the tunnel command generating unit 460 to generate and transmit a secure communication tunnel negotiation response command. If the tunnel command is a secure communication tunnel negotiation response command, the tunnel command processing unit 450 issues an instruction to the tunnel negotiating unit 410 to negotiate with the tunnel server at the opposite end with respect to encryption/de-encryption parameters.
The tunnel command generating unit 460 is used to generate corresponding tunnel commands in accordance with the instructions from the tunnel command processing unit 450 so as to perform an encryption of the tunnel commands and then transmit it to a destination address. The corresponding tunnel commands described herein include tunnel establishment commands, tunnel negotiation commands, tunnel negotiation response commands, or tunnel cancellation commands. If the tunnel command generating unit 460 is a tunnel command generating unit within the destination tunnel server, it generates the tunnel commands including tunnel establishment commands (if the identity authenticating unit is disposed within the destination tunnel server), tunnel negotiation commands, and tunnel cancellation commands. If the tunnel command generating unit 460 is a tunnel command generating unit within the source tunnel server, it generates the tunnel commands including tunnel negotiation response commands.
Alternatively, the tunnel server 400 may further include an identity authenticating unit 470 that is used to perform an identity authentication of the source host within the external network. The identity authenticating unit 470 acquires from an AAA server within the public network a network address range of the private LANs corresponding to the subscriber name in accordance with the identity authentication information transmitted from the source host within the external network. The identity authentication information includes subscriber names, subscriber passwords, IP addresses and port numbers of the destination hosts, and IP addresses of the source hosts. Thereafter, the identity authenticating unit 470 checks whether or not the subscriber name and password belong to legal subscribers of the private LAN and whether or not the destination host to be subjected to access belongs to the private LAN. If it has been checked that the subscriber is one of legal subscribers, this subscriber is entitled to access to the private LAN.
There has been disposed within the public network an AAA (Authentication, Authorization, Accounting) server, which is a universal server intended for authentication, authorization and accounting, and belongs to the prior art.
It is worthy to be noted that the identity authenticating unit 470 may be disposed in other places than within the tunnel server 400. In general, the identity authentication processing unit 470 may flexibly undergo an independent disposition on the servers (such as AAA servers) within the public network, instead of the restricted disposition on the tunnel servers.
The next description is presented in detail with regard to the encryption or de-encryption performed on the IP data packet. The IP data packet is subjected to encryption/de-encryption process at the source tunnel server and the destination tunnel server in accordance with the security policies derived from their negotiation with each other and the security unions corresponding to the security policies. The security policies and the security unions are stored in the security policy & security union database, such a database belongs to the prior art. In the present embodiment, the security policy & security union database is included in the database 430. As apparent from
The dynamic tunnel establishment method described above for securely accessing to the private LAN has the following beneficial effects over the prior secure communication tunnel establishment method:
Firstly, the dynamic tunnel establishment method described above has an automatic capability: it is possible to dynamically and automatically establish the secure communication tunnel without any manual intervention, there is no influence to the dynamic tunnel establishment method in spite of networking components having changed. Moreover, the secure communication tunnel may be canceled upon having completed communications.
Secondly, the dynamic tunnel establishment method described above has a facilitation: the secure tunnel is transparent with respect to the subscribers, who therefore need not keep in memory any addresses of tunnel servers, which leads the use of the subscribers easier.
Thirdly, the dynamic tunnel establishment method described above supports for the simple hosts: the establishment of the secure communication tunnel in the present method is fully accomplished by the devices (including AAA servers, tunnel servers or the like) of network service provider (NSP). Except for providing identity authentication information, the source hosts within the external network need no configuration and process in relation to the negotiation and establishment of the secure communication tunnels. Therefore, there is no need to install those support software and hardware in relation to the negotiation and establishment of the secure communication tunnels. With the present method, those hosts relatively simply in software and hardware are also able to dynamically establish the secure communication tunnels for accessing to the private LANs.
While the present invention has been described in detail with reference to the above preferred embodiments, various options, modifications, variations, improvements and/or basic equivalent techniques are apparent for the ordinary skilled in the art from the known contents at present. Therefore, the preferred embodiments of the present invention are intended for illustrative not restricted description of the present invention. Various changes can be made without departing from the spirit and scope of the present invention. Thus, the present invention may contain all of known and under-developing options, modifications, variations, improvements and/or basic equivalent techniques.
Number | Date | Country | Kind |
---|---|---|---|
200510030524.6 | Oct 2005 | CN | national |