1. Field of the Invention
The present invention relates generally to mobile networking, and more particularly, to an authentication and access control system for reducing the time required for a mobile user to authenticate to a new communications network.
2. Description of the Related Art
A user having a network access device (mobile host), who moves from a location covered by the user's home network to another location covered by a foreign access network, can be characterized as “roaming” between networks. Typically, the complicated handoff procedure that enables the mobile host to gain access to the new network can cause QoS problems. When the mobile host moves from the coverage of one network and roams into the coverage of the new or “arriving” network, three basic actions occur to effectuate a handoff: (1) the mobile host authenticates to the arriving network; (2) the arriving network allocates resources for the mobile host; and (3) the departing network releases any resources allocated to the mobile host. When a mobile host authenticates to a foreign network that is under a different administration than the departing network, the authentication step can be relatively time consuming. A typical authentication scenario is illustrated in
In view of the above, it is an object of the present invention to provide a novel authentication/access control method that improves the handoff process for a mobile host that roams between networks.
It is another object of the present invention to reduce the authentication time for a mobile host to access a foreign network.
It is a further object of the invention to reduce the workload of remote authentication servers by offloading a portion of the authentication process for a network access device from the remote server to access points on the network.
In accordance with these and additional objects that will become apparent hereinafter, an aspect of the invention provides a system including an access point having a network interface for communicating with a remote authentication server on a communications network and a network interface for communicating with a network access device. The access point comprises a processor and a memory medium containing machine readable program instructions which, when executed by the processor, enable the access point to: validate an authentication credential contained in an access request received from the network access device. If the authentication credential is validated, the access point grants the network access device conditional access to the network, contacts the remote authentication server to verify a status of the authentication credential for the network access device; and suspends network access for the network access device in response to a message received from the remote authentication server that the authentication credential for the network access device has been revoked. Another aspect of the invention provides a remote authentication server having a processor and a memory medium containing machine readable program instructions which, when executed by the processor, enable the remote authentication server to determine the status of the authentication credential received in a query from the access point, to either confirm access to the network for the network access device or, if the authentication credential is revoked, send the access point a message to suspend access to the network for the network access device.
The present invention will now be described in detail with particular reference to the accompanying drawings.
Referring now to the several views of the drawings,
Referring to
The mobile host 200 includes memory 206 with a CURRENT_CERTIFICATE register 208, a CURRENT_PRIVATE_KEY register 210, a NEXT_CERTIFICATE register 212, and a NEXT_PRIVATE_KEY register 214. A current security certificate is stored in the CURRENT_CERTIFICATE register 208. A current private key is stored in the CURRENT_PRIVATE_KEY register 210. The specifics of these details are described in greater detail below.
The foreign AP 202 includes or is otherwise associated with a Business Partner Database 216, Revoked Certificate Database 218, and an Access Control Database 220. The Business Partner Database 216 contains the public keys for the mobile host's home AAA server 204. The Revoked Certificate Database 218 contains security certificates that have been revoked before expiration. The Access Control Database 220 stores session keys for the mobile host(s). The foreign AP 202 has memory 222 including a CURRENT_PUBLIC_KEY register 224 and a NEXT_PUBLIC_KEY register 226. The current public key of the home AAA server is stored in the CURRENT_PUBLIC_KEY register 224. These are all explained in greater detail hereinbelow.
The home AAA server 204 includes or is otherwise associated with a Certificate Database 228 and Subscriber Database 230. The Certificate Database 228 contains records that include parameters for the mobile user. The Subscriber Database 230 contains subscriber information for each mobile user that has an account with the network service provider.
Referring to
At 302, after receiving the security certificate, the AP checks the signature and expiration time of the security certificate. The AP should have the public key of the mobile host's home AAA server, denoted as KHAAA
Referring now to
Referring now to
Referring now to
The details of authentication/access control, and key management are shown and described hereinafter. Authentication and access control can be implemented at either layer 2 or layer 3 of the OSI network model. With regard to layer 2, the AP handles authentication and access control issues based on link layer data frames. Every data frame has the form of “Frame Header∥KSN(Frame Payload)∥Hash (KSN∥Hash (Frame Header∥Frame Payload))”. In a layer 3 implementation, an access gateway sitting behind the access points handles authentication and access control issues based on network layer data packets, such as IP packets. In this case, every packet has the form of “Packet Header∥KSN(Packet Payload)∥Hash (KSN∥Hash (Packet Header∥Packet Payload))”, and the AP may need to handle access control issues by snooping network layer packets.
Tasks associated with key management include updating the security certificates for individual mobile users, and public/private keys for the respective home AAA servers. It will be understood that security certificates for individual mobile users require more frequent updates than the public/private keys for the home AAA server. To simplify key management, the expiration time for the home AAA server's public/private keys should be synchronized with the expiration time of all security certificates issued by the home AAA server. Accordingly, the life cycle for a public-private key pair for the home AAA server can be represented as an integer times of the life cycle of any security certificates.
The security certificate for a mobile user can be updated using mutual authentication between the mobile host and its home AAA server. To assure acceptable future secrecy, an updating session can utilize a method such that disclosed in U.S. Patent Appl. Ser. No. 60/338,922, entitled “A General Method To Establish A Secure Connection For Off-The-Record Communications,” filed Dec. 10, 2001. In accordance with this implementation, the disclosure of a private key for a previous, expired security certificate doesn't compromise the private key for a current security certificate.
To demonstrate an illustrative protocol, the following assumptions are made for a mobile host and the host's home AAA server.
1. At time t0, a security certificate for a mobile user becomes effective, and at time t0+T, the security certificate expires.
2. The mobile host knows the host name or IP address of its home AAA server based on its configuration parameters.
3. The mobile host has a CURRENT_CERTIFICATE register, a CURRENT_PRIVATE_KEY register, a NEXT_CERTIFICATE register, and a NEXT_PRIVATE_KEY register (see
4. The home AAA server to generate security certificates and corresponding private keys. Alternatively, the mobile hosts can generate these keys assuming sufficient computing power.
5. The home AAA server has a certificate database. Each record in the database includes the following parameters for a mobile user: current security certificate, next certificate, next private key, and a revoke flag.
Referring now to
At 706, the CERTIFICATE_UPDATE_REQUEST message is received by the home AAA server. At 708, the home AAA server checks the signature of the security certificate in the message, and checks to see whether the security certificate has been revoked. At 710, if either the signature is not verified or the certificate has been revoked, the process fails. At 712, if the signature is verified and the certificate has not been revoked, and a CERTIFICATE_UPDATE_REPLY message has not been sent to the mobile host, the home AAA server at 714 either retrieves the next security certificate and the next private key from the certificate database, or generates them for the mobile host (effective from t0+T to t0+2T). The home AAA server casts a random number y, calculates Y=p^y mod q and K=y^X mod q, and encrypts the new security certificate and corresponding private key using K as the key. At 716, this encrypted message is sent to the mobile host in the form of a CERTIFICATE_UPDATE_REPLY. This message contains the encrypted next security certificate, the encrypted next private key and the Diffie-Hellman parameters Y, p, and q. The entire message is signed using the current private key of the home AAA server. This enables the mobile host to verify that this message was sent from the home AAA server.
After receipt of the CERTIFICATE_UPDATE_REPLY message, at 718 the mobile host first checks the signature of the message. If the signature is verified at 720, the mobile host calculates K=x^Y mod q, decrypts the next security certificate and the next private key using K as the key at 722, and saves them in the NEXT_CERTIFICATE register and the NEXT_PRIVATE_KEY register respectively at 724.
If the clock reaches t0+T at 726, the mobile host copies the next security certificate from the NEXT_CERTIFICATE register to the CURRENT_CERTIFICATE register at 728, then sets the NEXT_CERTIFICATE register to zero at 730. The same procedure is implemented with the CURRENT_PRIVATE KEY register and the NEXT_PRIVATE_KEY register. At the same time, the home AAA server will update its certificate database accordingly. It is unnecessary for the clocks to be precisely synchronized between the mobile host and the home AAA server. From t0+T−Δt to t0+T+Δt, both security certificates are honored.
To update public and private keys for a home AAA server, the home AAA server only needs to be authenticated to the APs and therefore encryption is unnecessary. The home AAA server distributes new public keys that are adopted by the home AAA server to the various APs.
For the purpose of illustration herein, the following are assumed for a home AAA server and an AP:
1. A public/private key pair for the home AAA server becomes effective at time t0, and expires at t0+T.
2. The AP knows the host name or IP address of the home AAA server based on its configuration parameters.
3. The AP has a CURRENT_PUBLIC_KEY register (222,
An illustrative protocol is depicted in
At time t0, the home AAA server generates the next public/private key pair for itself at step 800. These key pair are effective during [t0+T, t0+2T]. At 802, the AP randomly picks a time between t0 and t0+T/2 and requests the next public key from the home AAA server (this prevents multiple APs from making simultaneous requests to the home AAA server). At 804, the AP sends a PUBLIC_KEY_REQUEST message to the home AAA server. If a PUBLIC_KEY_RESPONSE message is not received at 806, the AP will repeatedly send the PUBLIC_KEY_ACCESS request message at a sparse cycle until the corresponding PUBLIC_KEY_RESPONSE message is received (which means success) or at 808 the current public/private key pair for the home AAA server expires (which means failure).
After receiving the PUBLIC_KEY_REQUEST message, at 810 the home AAA server replies with a PUBLIC_KEY_RESPONSE message to the AP. This message contains the next public key to be used. The message is signed using current private key of the home AAA server, so that the AP is convinced that the message indeed originated from the home AAA server. The AP checks the signature of the PUBLIC_KEY_RESPONSE message at 812. If the signature is verified at 814, the AP saves the public key in the NEXT_PUBLIC_KEY register at 816. At 818, if the clock has reached t0+T, the AP copies the content of the NEXT_PUBLIC_KEY register to the CURRENT_PUBLIC_KEY register at 820, and sets the NEXT_PUBLIC_KEY register to zero at 822. Concurrently, the home AAA server starts using the new public/private key pair and destroys the old key pair. As discussed above with respect to the mobile host, it is unnecessary for the clocks between the home AAA server and AP to be precisely synchronized from t0+T−Δt to t0+T+Δt since both public keys are honored.
The present invention has been shown and described in what are considered to be the most practical and preferred embodiments. It his anticipated, however, that departures may be made therefrom and that obvious modifications will be implemented by those skilled in the art.
This application is a continuation of U.S. patent application Ser. No. 10/145,301, filed May 14, 2002 now U.S. Pat. No. 6,856,800, entitled “Fast Authentication and Access Control System for Mobile Networking”, which claims benefit of U.S. Provisional Patent Application Ser. No. 60/290,776, filed May 14, 2001, the contents of which are both incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5757920 | Misra et al. | May 1998 | A |
5982898 | Hsu et al. | Nov 1999 | A |
6041317 | Brookner | Mar 2000 | A |
6075860 | Ketcham | Jun 2000 | A |
RE36946 | Diffie et al. | Nov 2000 | E |
6198823 | Mills | Mar 2001 | B1 |
6212634 | Geer et al. | Apr 2001 | B1 |
6233341 | Riggins | May 2001 | B1 |
6236852 | Veerasamy et al. | May 2001 | B1 |
6397056 | Bugnon et al. | May 2002 | B1 |
6490445 | Holmes | Dec 2002 | B1 |
6516316 | Ramasubramani et al. | Feb 2003 | B1 |
6772331 | Hind et al. | Aug 2004 | B1 |
6856800 | Henry et al. | Feb 2005 | B1 |
7174456 | Henry et al. | Feb 2007 | B1 |
7174564 | Weatherspoon et al. | Feb 2007 | B1 |
20020042820 | Strom | Apr 2002 | A1 |
20020147820 | Yokote | Oct 2002 | A1 |
20030166397 | Aura | Sep 2003 | A1 |
20030236985 | Ruuth | Dec 2003 | A1 |
Number | Date | Country |
---|---|---|
0939571 | Sep 1999 | EP |
Number | Date | Country | |
---|---|---|---|
60290776 | May 2001 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10145301 | May 2002 | US |
Child | 11047905 | US |