PASSWORD-BASED AUTHENTICATION IN SERVER SYSTEMS

Information

  • Patent Application
  • 20170104745
  • Publication Number
    20170104745
  • Date Filed
    October 08, 2015
    9 years ago
  • Date Published
    April 13, 2017
    7 years ago
Abstract
A system of λ≧2 servers is provided. The server system comprises an access control server for communication with user computers via a network and controlling access by the user computers to a resource in dependence on authentication of user passwords associated with respective user IDs, and a set of authentication servers for communication with the access control server via the network. In this system, at least each authentication server stores a respective key-share Ki of a secret key K which is shared between a plurality of the λ servers. The access control server is adapted, in response to receipt from a user computer of a user ID and an input password, to produce a hash value h via a first hash function operating on the input password. The access control server blinds the hash value h to produce a blinded hash value u, and sends the blinded hash value u via the network to at least a subset of the set of authentication servers. Each authentication server is adapted, in response to receipt of the blinded hash value u, to produce a hash response vi from the blinded hash value u and that server's key-share Ki, and to send the hash response vi via the network to the access control server. The access control server is further adapted to produce, using the hash response vi from each authentication server, an input password hash comprising a predetermined function of said hash value h and said secret key K. The access control server compares the input password hash with a corresponding user password hash, produced from the user password for the received user ID and pre-stored by the access control server, to determine whether the input password equals the user password, if so permitting access to the resource by the user computer.
Description
BACKGROUND

The present invention relates generally to password-based authentication in server systems, and more specifically to password-based authentication in plural-server systems whereby access to a resource is controlled in dependence on authentication of user passwords by the server system.


Passwords are still the most prevalent mechanism for user authentication in data processing systems. In conventional password-based authentication systems, users connect to a server which controls access to the protected resource and maintains a database of user IDs, e.g. user names, with their associated user passwords stored in simple hashed form. If the access control server is compromised, however, user passwords are vulnerable to offline attacks using dictionaries or brute-forcing of the message space. As current graphical processors can test many billions of combinations per second, security should be considered lost as soon as an offline attack can be mounted against the password data.


To reduce exposure to offline attack through server compromise, password-based authentication can be performed by a plurality of servers. The authentication data can be split between multiple servers, and the user then interacts with all servers in the authentication protocol since information of all servers is required for authentication. This improves security as more than one server must be hacked for user passwords to be compromised. An example of a multi-server authentication system is described in “Round-optimal password-protected secret sharing and T-PAKE in the password-only model”, Jarecki et al., ASIACRYPT 2014, Part II.


Resistance against server compromise is one thing, but knowing how to recover from such an event is another. Without secure recovery, all one can do in case of a detected breach is to re-initialize all servers with fresh cryptographic keys for the authentication protocol and request all users to reset their passwords. In cryptographic literature, recovery from compromise is known as proactive security or security against transient corruptions. Proactive security can be realized by letting the servers engage in an interactive refresh protocol to re-compute their keys.


SUMMARY

According to at least one embodiment of the present invention there is provided a system of λ≧2 servers. The server system comprises an access control server for communication with user computers via a network and controlling access by the user computers to a resource in dependence on authentication of user passwords associated with respective user IDs, and a set of authentication servers for communication with the access control server via the network. In this system, at least each authentication server stores a respective key-share Ki of a secret key K which is shared between a plurality of the λ servers. The access control server is adapted, in response to receipt from a user computer of a user ID and an input password, to produce a hash value h via a first hash function operating on the input password. The access control server blinds the hash value h to produce a blinded hash value u, and sends the blinded hash value u via the network to at least a subset of the set of authentication servers. Each authentication server is adapted, in response to receipt of the blinded hash value u, to produce a hash response vi from the blinded hash value u and that server's key-share Ki, and to send the hash response vi via the network to the access control server. The access control server is further adapted to produce, using the hash response vi from each authentication server, an input password hash comprising a predetermined function of said hash value h and said secret key K. The access control server compares the input password hash with a corresponding user password hash, produced from the user password for the received user ID and pre-stored by the access control server, to determine whether the input password equals the user password, if so permitting access to the resource by the user computer.


Further embodiments of the present invention provide access control and authentication servers of such systems and methods performed thereby.


Embodiments of the invention will be described in more detail below, by way of illustrative and non-limiting example, with reference to the accompanying drawings.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS


FIG. 1 is a schematic representation of a data processing system including a server system embodying the invention;



FIG. 2 is a generalized schematic of a computer in the server system of FIG. 1;



FIG. 3 indicates steps performed in an authentication operation of the server system;



FIG. 4 indicates steps performed in a setup operation of the server system;



FIG. 5 is a schematic representation of an exemplary server implementation for the FIG. 1 system;



FIGS. 6 and 7 indicate steps performed by servers in an initialization procedure of one embodiment;



FIG. 8 indicates steps performed by servers in an authentication operation of the embodiment; and



FIG. 9 indicates steps performed by servers in a refresh operation of the embodiment.





DETAILED DESCRIPTION


FIG. 1 is a schematic block diagram of a data processing system incorporating a server system 1 embodying the invention. The server system 1 comprises λ≧2 servers. These include an access control server 2, denoted by S0, and a set of n≧1 authentication servers 3, denoted by S1 to Sn. The access control server 2 is adapted for communication with the authentication servers 3 and a plurality of user computers 4 via a network 5. The network 5 may in general comprise one or more component networks and/or internetworks, including the Internet. The user computers 4 are shown as general-purpose personal computers (PCs) in this example, but may equally be implemented by other computer devices such as mobile phones, tablet computers, personal music players, palmtop devices, etc. The n authentication servers 3 are adapted to cooperate with the access control server 2 to implement a password authentication protocol detailed below. In particular, access control server 2 controls access by user computers 4 to a resource, in this example a database 6. Access is permitted in dependence on authentication of user passwords associated with respective user IDs, e.g. user names, which are input by users via PCs 4 in operation.


The number n of authentication servers can vary for different embodiments. In preferred embodiments, n>1 whereby system 1 comprises λ≧3 servers. In general, higher values of n offer greater system security, and the value of n can be selected as desired depending on the particular password authentication protocol and required level of security. The authentication servers 3 may be located at the same location as access control server 2 or at one or more different locations, and may be controlled by the same entity as the access control server or by one or more different entities. Distribution and control of the servers 2, 3 can thus be selected according to security requirements for a given system.


A high-level abstraction of functional components of the servers 2, 3 is shown in FIG. 1. Access control server 2 is indicated as comprising a communications interface (I/F) 7 for communications via network 5, access control logic 8, and storage 9. The access control logic 8 provides functionality for implementing steps of the password authentication and related operations detailed below. In general, this control logic can be implemented in hardware or software or a combination thereof. Storage 9 stores various data used by the control logic 8 in operation. This includes a password data set {uid:PH} containing a user password hash PH, the construction of which is detailed below, for the user ID uid of each registered user of the authentication system. In preferred embodiments the access control server also stores a key-share K0 of a secret key K, and a public key L of a cryptographic key-pair, discussed further below. Each authentication server 3 is similarly shown as comprising a communications interface 11, authentication logic 12 and storage 13. The authentication logic 12 (which can again be implemented in hardware or software or a combination thereof) provides functionality for use in the password authentication and related operations below. Storage 13 stores data used by authentication logic 12 in operation. In particular, at least each authentication server S1 to Sn stores a respective key-share Ki of a secret key K which is shared between a plurality of the λ servers Si (i=0 to n) of system 1. Hence, in systems where=2, the access control server S0 necessarily stores a key-share K0. In systems where n>1, at least each of the n authentication server S1 to Sn stores a respective key-share K1 to Kn, and access control server S0 preferably also stores a key-share K0. The key-sharing scheme, examples of which will be described below, is such that the secret key K for the authentication protocol can be reconstructed in operation from a combination of key-shares Ki.


Each of the functional blocks of servers 2, 3 in FIG. 1 may be implemented in general by one or more functional components which may be provided by one or more computers. In particular, each of servers 2, 3 may be implemented by computing apparatus comprising one or more general- or special-purpose computers, each comprising one or more (real or virtual) machines, providing functionality for implementing the operations described herein. Exemplary implementations will be described further below. The access control and authentication logic 8, 12 of these servers may be described in the general context of computer system-executable instructions, such as program modules, executed by a computing apparatus. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. The computing apparatus may be practiced in distributed cloud computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed cloud computing environment, data and program modules may be located in both local and remote computer system storage media including memory storage devices.



FIG. 2 is a block diagram of exemplary computing apparatus for implementing a computer of server system 1. The computing apparatus is shown in the form of a general-purpose computer 15. The components of computer 15 may include processing apparatus such as one or more processors represented by processing unit 16, a system memory 17, and a bus 18 that couples various system components including system memory 17 to processing unit 16.


Bus 18 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus.


Computer 15 typically includes a variety of computer readable media. Such media may be any available media that is accessible by computer 15 including volatile and non-volatile media, and removable and non-removable media. For example, system memory 17 can include computer readable media in the form of volatile memory, such as random access memory (RAM) 19 and/or cache memory 20. Computer 15 may further include other removable/non-removable, volatile/non-volatile computer system storage media. By way of example only, storage system 21 can be provided for reading from and writing to a non-removable, non-volatile magnetic medium (commonly called a “hard drive”). Although not shown, a magnetic disk drive for reading from and writing to a removable, non-volatile magnetic disk (e.g., a “floppy disk”), and an optical disk drive for reading from or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD-ROM or other optical media can also be provided. In such instances, each can be connected to bus 18 by one or more data media interfaces.


Memory 17 may include at least one program product having one or more program modules that are configured to carry out functions of embodiments of the invention. By way of example, program/utility 22, having a set (at least one) of program modules 23, may be stored in memory 17, as well as an operating system, one or more application programs, other program modules, and program data. Each of the operating system, one or more application programs, other program modules, and program data, or some combination thereof, may include an implementation of a networking environment. Program modules 23 generally carry out the functions and/or methodologies of embodiments of the invention as described herein.


Computer 15 may also communicate with: one or more external devices 24 such as a keyboard, a pointing device, a display 25, etc.; one or more devices that enable a user to interact with computer 15; and/or any devices (e.g., network card, modem, etc.) that enable computer 15 to communicate with one or more other computing devices. Such communication can occur via Input/Output (I/O) interfaces 26. Also, computer 15 can communicate with one or more networks such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet) via network adapter 27. As depicted, network adapter 27 communicates with the other components of computer 15 via bus 18. It should be understood that although not shown, other hardware and/or software components could be used in conjunction with computer 15. Examples include, but are not limited to: microcode, device drivers, redundant processing units, external disk drive arrays, RAID systems, tape drives, and data archival storage systems, etc.



FIG. 3 gives an overview of the main steps performed by server system 1 in an authentication operation. The authentication procedure is initiated when a user connects to access control server (AC server) 2 from a user computer 4 over network 5. The user supplies his user ID uid and an input password p′ (i.e. an attempt at his user password p as previously registered with the AC server in a setup procedure detailed below). The login data (uid, p′) is received by AC server 2 in step 30 of FIG. 3. In step 31, the control logic 8 of AC server 2 produces a hash value h via a first hash function H operating on (at least) the input password p′. In step 32, the control logic 8 blinds the hash value h to produce a blinded hash value u. (Blinding is a widely-used cryptographic procedure whereby a message can be hidden, or blinded, by encoding the message using a selected function, typically combining the message with a random value such as a nonce). In step 33, the access control server 2 sends the blinded hash value u via the network to at least a subset of the set of n authentication servers 3.


In response to receipt of the blinded hash value u, the authentication logic 12 of each authentication server 3 produces a hash response vi as indicated at step 34. This hash response vi is produced from (at least) the blinded hash value u and that server's key-share Ki of the secret key K. The hash response vi is denoted in step 34 by f(u, Ki), where ƒ is some function of which examples are given below. In step 35, each authentication server sends its hash response vi back to AC server 2 via the network.


On receipt in step 36, the control logic 8 of AC server 2 uses (at least) the hash responses vi to produce a predetermined function F of the aforementioned hash value h and the secret key K. In this computation, the key-shares Ki needed to reconstruct the key K are combined to produce the function F of h and K. These key-shares comprise the key-share Ki encoded in each hash responses vi from an authentication server, and may also include the AC server's own key-share K0 where provided. An input password hash PH′, comprising (at least) the function F(h, K), is produced as indicated at step 37. While the input password hash PH′ may simply be the function F(h, K) here, preferred embodiments further encode F(h, K) to produce PH′ as illustrated by examples below. Next, the access control logic 8 compares the input password hash PH′ with a corresponding user password hash PH pre-stored in storage 9 for the received user ID uid. The user password hash PH is produced in corresponding manner from the user password p registered for uid in a setup operation for the user account. The setup operation, described below, thus includes steps which correspond generally to steps 30 to 37 above to produce the user password hash PH from the user password p. If the input password hash PH′ matches the user password hash PH, as indicated by a “Yes” (Y) at decision block 38, then the input password p′ equals the user password p. In this case, the AC server 2 permits the user computer access to the database 6 as indicated at step 39, and the login process in complete. If the input password p′ does not equal the user password p, then the password hashes PH′ and PH will not match, giving decision “No” (N) at block 38. The AC server 2 then denies access at step 40 and may notify the user accordingly.


In the above process, the number of authentication servers to which the blinded hash value u is sent in step 33 may depend on the nature of the key-sharing scheme. In particular, some schemes (so called “n-out-of- n” schemes where “n” here is the total number of key-shares Ki) require all key-shares Ki in order to reconstruct the shared key K. In this case, the blinded hash value will be sent to all authentication servers. Other key-sharing schemes are so-called threshold (or “t-out-of-n”) schemes in which only a threshold number t of key-shares, (where t can be less than the total number n of key-shares) are required to reconstruct the key K. In this case, the blinded hash value u may be sent to a subset of t (or (t-1) if the access control server holds a key-share K0) authentication servers.


The above scheme provides the basis for highly efficient, secure password authentication procedures in which proactive security can be achieved by simple redistribution (or “refresh”) of the key-shares Ki. Since the password hash PH is a function of the shared key K, offline attacks on any given server cannot compromise the user password. The key-shares can be refreshed in such a way that the overall secret key K is unchanged, so no re-computation of the pre-stored PH value is required. Preferred embodiments detailed below provide a simple, non-interactive key-refresh procedure whereby key-shares can be refreshed unilaterally by each server, i.e. without requiring communication between the servers. The key-shares here can be based on sets of master keys stored by respective servers. Such master keys can be readily protected in operation of the system, and can also be used in an elegant scheme for blinding hash responses of the authentication servers. This enhances security of the system, providing proactive security over arbitrarily many key-refresh procedures. The password authentication process is distributed over a plurality of servers, enhancing security against offline attacks, yet the user need only interact with a single server, i.e. the access control server. The password verification is a single-round protocol which can be implemented in a highly efficient manner. Registration of user passwords on setup of user accounts can also be achieved via an efficient setup procedure. The preferred setup operation further allows simple verification of correct computation of the user password hashes on which successful login subsequently depends.



FIG. 4 gives an overview of the preferred setup operation including the aforementioned verification step. To permit this verification, the secret key K for system 1 comprises the secret key of a cryptographic key-pair (L, K), where L is the public key of the key-pair. This public key L is stored by AC server 2 as indicated above. To initiate the setup operation for a user account, the user supplies his user ID uid and a user password p to the AC server 2. The user data (uid, p) is received by AC server 2 in step 45 of FIG. 4. In step 46, the control logic 8 produces an initial hash value h0. This value h0 is produced in corresponding manner to the hash value h in step 31 of FIG. 3, i.e. by applying the first hash function H to (at least) the user password p. In step 47, the initial hash value h0 is blinded as in step 32 above to produce a blinded initial hash value u0. In step 48, the blinded initial hash value u0 is sent to to at least a subset of the n authentication servers 3. In step 49, the authentication logic 12 of each authentication server produces an initial hash response vi0, in like manner to step 34 above, as f(u0, Ki). Each authentication server sends its initial hash response vi0 back to AC server 2 in step 50. In step 51, the control logic 8 of AC server 2 uses the initial hash responses vi0 to produce the function F(h0, K) of the initial hash value h0 and secret key K in like manner to step 36 above. Next, in step 52, the control logic 8 uses the public key L to verify correctness the secret key K in the function F(h0, K). This can be done in various ways depending on the particular protocol construction. In some embodiments, the AC server communicates with the authentication servers which provided initial hash responses vi0 in step 49 to implement a zero-knowledge proof using the public key L. In other embodiments, the control logic 8 can simply verify that the public key L and the function F(h0, K) satisfy a bilinear map. Examples of both constructions are given below. In step 53, the user password hash PH, comprising the function F(h0, K), is produced as in step 37 above. The user password hash PH is stored for the uid in the password data set of storage 9 in step 54. The setup procedure for the user is then complete.


The verification operation of step 52 above ensures that the authentication servers have behaved honestly in computation of their initial hash responses using the correct key-shares K1, and hence that the user password hash PH is a correct function of the user password p and secret key K. Without this step, successful login for a user account would be impossible. However, additional verification of the input password hash PH′ during subsequent logins is unnecessary. Mismatch of the password hashes PH′ and PH in step 38 of the login procedure indicates either that the input password p′ is incorrect, or that an authentication server has not supplied a valid hash response vi, suggesting system compromise. In both cases login is justifiably refused.


A simple embodiment of the above procedure can be implemented as follows. A straightforward way to secret-share a secret key K, being an element of a group G, among servers S0, . . . , Sn is to choose random key-shares K1, . . . , Knr G and set







K
0



K
-




i
=
1

n




K
i

.







Each server Si is given a key-share Ki. The key K can then be reconstructed as






K





i
=
0

n








K
i

.






Steps 31 to 37 of FIG. 3 can be performed as follows.


Step 31: the hash value h is computed as h=H(uid, p′).


Step 32: control logic 8 selects a random nonce N and computes the blinded hash value u as






u=h
N
=H(uid, p′)N.


Step 34: each authentication server computes is hash response vi as vi=uKi.


Step 36: control logic 8 computes v0=uKo and computes v=F(h, K) as






v
=





i
=
0

n







v
i

1
N



=





i
=
0

n







u


K
i

N



=



H


(

uid
,

p



)



Σ






K
i



=


h
K

.








Step 37: control logic 8 computes the input password hash PH′ via a second hash function G operating on the function F(h, K)=v, in this case together with the input password p′ and the user ID uid, as





PH′=G(uid, p′, v)=G(uid, p′, H(uid, p′)ΣKi)=G(uid, p′, hK).


The equivalent steps of FIG. 4 can be performed in a corresponding manner to compute the user password hash PH from user password p.


To provide security against transient corruptions, the servers Si refresh their key-shares Ki for each of successive time periods in operation of the system. In preferred implementations of this refresh process, each server Si adds a random share of a predetermined value, most conveniently zero, to its current key-share. The sum of the key-shares










i
=
0

n







K
i


=
K




thus remains the same, and the user password hash remains valid. The time periods, or “epochs”, for which the key-shares are refreshed may be defined in various ways in the system. For example, the refresh operation may be performed automatically for epochs of a predetermined duration, and/or a new epoch may be initiated in response to detection of an attack on system 1. In the preferred embodiments to follow, the refresh operation is a simple, non-interactive process, performed unilaterally by each server, in which the key-shares are based on sets of master keys stored by the servers. These master keys also form the basis for a clever system of blinding hash responses of the authentication servers. This blinding system allows keys to be refreshed over arbitrarily many epochs, providing continued security against transient corruptions, while avoiding the need for servers to commit to their key-shares. To protect these master keys, in preferred embodiments of system 1, each server Si storing a key-share Ki comprises a first and second server compartments. The first server compartment is connectable to network 5 and is operable, though communication with other servers Si as described above, to implement the authentication protocol. The second server compartment stores the set of master keys for the server and is inaccessible from network 5 in operation of the authentication protocol. This server compartment can be protected from network 5 by hardware and/or software mechanisms which inhibit unauthorized access to the compartment from the network in operation of the protocol. A preferred implementation for the servers Si will now be described with reference to FIG. 5.


In server 60 of FIG. 5, the first server compartment 61 comprises a virtual machine 62, denoted by SCi(2) (where ε=0, 1, 2, etc., indicates epoch number), running on a cloud computing platform 63. A fresh virtual machine SC1i(0), SC1i(1), SC1i(2), etc., is initiated on platform 63 for each of successive epochs ε=0, 1, 2, . . . , etc., in operation. Cloud platform 63 may in general comprise one or more computers each supporting one or more virtual machines. In a typical implementation, the cloud platform 63 can be realized by a single physical machine or a cluster of physical machines. The second server compartment 64, denoted by SC2i, comprises a single physical machine in this embodiment. This machine is connected only to the cloud software platform, and such connections can be physically isolated from the network 5 (here assumed to be the Internet) via which the virtual machines 62 communicate. In particular, the virtual machines SC1i(0), SC1i(1), . . . , SC1i(2), . . . , are exposed to the Internet, while the cloud platform 63 and second compartment SC2i are run in a protected environment (the “de-militarized zone”), i.e. behind one or more firewalls deployed in the cloud platform. The second compartment SC2i is thus inaccessible from the Internet in normal operation of the authentication protocol, and is therefore protected from unauthorized Internet access. (Authorized access may of course be possible if required, e.g. for setup purposes prior to operation).


The second server compartment SC2i of server 60 stores a set of master keys, denoted by {mk}i in the figure, for the server Si, together with the public key L discussed above. The key set {mk}, may in general comprise one or more master keys, one or more of which may be common to one or more other servers Si as explained below. The first server compartment SC1i stores that server's current key-share Ki of the secret key K, together with a set of blinding seeds, denoted by {s}i, discussed further below.


The master key sets {mk}i and initial key-shares Ki for servers Si may be provided in an initialization operation of the system. This initialization might be performed in various ways. For example, the master keys {mk}, could be generated independently, e.g. by a system controller, and communicated to individual servers Si via some secure message transmission functionality Fsmt. In embodiments below, one dedicated server, here AC server S0, generates all master key sets {mk}i which are then communicated to other servers via the secure message transmission functionality Fsmt. This communication may, for example, be implemented by writing the initialization data to a physical medium (such as a USB drive, disc, etc.) which is distributed to server locations by courier and loaded to the servers by an operator. In some embodiments, master keys may even be short enough to be written on paper and entered manually to the servers. Alternatively, for example, the message transmission functionality Fsmt may comprise a secure transmission channel established via a standard security protocol such as TLS (Transport Security Layer) or SSL (Secure Sockets Layer). While the initialization data could include the initial key-shares Ki, and blinding seeds {s}i, in the embodiments below this initial data can be generated by the second server compartments SC2i.


With the implementation of FIG. 5, server 60 can exploit inherent features of modern cloud computing platforms such as, for instance, the Openstack platform. Such platforms offer strong separation between the virtual machines which are exposed to the Internet, and are thus subject to attacks, and the cloud management interfaces that run in the demilitarized zone. New virtual machines can be created on the fly from images, machines can be shut down, and the routing of traffic to machines can be dynamically configured. The platforms can also virtualize the storage for the virtual machines, offering different kinds of abstraction of hard-disks (such as file system, block store, object store, etc.). System setup can be managed as a manual process via a web interface in the de-militarized zone. However, system management operations can easily be automated with scripts to replace manual interaction with software-based control.


In operation of system 1 with the server implementation of FIG. 5, the λ virtual machines SC1i(2) first server compartments 61 communicate to implement the authentication protocol. Time is divided into epochs separated by key refresh procedures performed by the servers. For each epoch ε, a fresh virtual machine SC1i(2) is set up, booted, and run on the cloud platform 63 at each server. These machines SC1i(2) run the setup and login procedures of authentication protocol, and read and write their states from the virtual storage provided to them by cloud platform 63. The second compartment SC2i of each server 60 controls the cloud platform 63, maintains the images for the virtual machines SC1i(2), and prepares the state (stored operating data) that is given to each SC1i (2) in order for it to run the protocol procedures.


Operation of a preferred embodiment using servers 60 will now be described with reference to FIGS. 6 through 9. Some preliminaries are described first to assist understanding of the embodiment to follow.


Combinatorial Secret Sharing. A straightforward way to create n-out-of-n secret shares of the unity element in a group G among parties P1, . . . , Pn is to choose shares α1, . . . , αnR G and set







a
1




1




i
=
2

n







a
i



.





Each party Pi is given a secret share αi. They are correct shares of one because










i
=
1

n







a
i


=
1.




An observation underlying the embodiment below is that the same shares α1, . . . , αn can be computed in a different way, by choosing b[i,j]←R G for all 1≦i<j≦n and handing (b[i,j])j=1,j≠i to Pi for i=1, . . . , n. Note that there is a share b[i,j] for each pair of parties {Pi, Pj}, and that this share is known only to Pi and Pj. Party Pi computes its share of unity








a
i







j
=
1

,

j

i


n







b

[

i
,
j

]


Δ

i
,
j





,




where Δi,j=1 if i<j or Δi,j=−1 otherwise. One can easily see that










i
=
1

n







a
i


=





i
=
1

n











i
=
1

,

i

i


n







b

[

i
,
j

]


Δ

i
,
j





=





i
=
1

n










i
=

i
+
1


n








b

[

i
,
j

]


·

b

[

i
,
j

]


-
1





=
1






The embodiment below exploits this technique for generating blinding factors β0, . . . , βn as random shares of unity by letting the b{i,j} be generated pseudorandomly from a master key that is known only to servers Si and Sj. Similarly, random shares δ1, . . . , δn of zero can be obtained by choosing δ2, . . . , δnR G, setting








δ
l



-




i
=
2

n







δ
i




,




and giving δi to Pi, whereby










i
=
1

n







δ
i


=
0.




Each party Pi can compute its share of zero δ as








δ
i







j
=
1

,

j

i


n








Δ

i
,
j


·

b

[

i
,
j

]





,




where represents multiplication and Δi,j is as defined above. Here it can be seen that










i
=
1

n








δ
i






i
=
1

n











j
=
1

,

j

i


n








Δ

i
,
j


·

b

[

i
,
j

]







-




i
=
1

n










j
=

i
+
1


n



(


b

[

i
,
j

]


-

b

[

i
,
j

]



)



-
0




This technique, in which the b[i,j] are generated pseudorandomly from a master key known only to servers Si and Sj, is used to enable each server Si to unilaterally update its key-share Ki in the embodiment below.



FIGS. 6 and 7 indicate an initialization procedure for servers Si in this embodiment. (Note that steps may be performed in a different order to that shown, and some steps may be performed concurrently as appropriate). It is assumed in this example that all servers S0, . . . , Sn store a key-share Ki of the secret key K. One dedicated server, here AC server S0, performs the initialization steps indicated in FIG. 6. In this process, the second server compartment SC20 of server S0, generates and distributes a set of master keys {mk}i for all servers S0, . . . , Sn in the system. It also generates a secret key K for a joint public key L. SC20 uses its master keys {mk}0 to compute its own initial key-share K0 of K and an initial set of blinding seeds {s}0. The key-share K0 and blinding seeds {s}0 form part of the initial state st0 of the first server compartment SC10 of S0. The master keys for S0 form part of the stored data backup0 held in memory of second server compartment SC20.


In step 70 of FIG. 6, the second server compartment SC20 of AC server 2 generates the master key sets for servers Si as {mk}i=(custom-charactermk{i,j})custom-characterj=o,j≠n for all 0≦i<j≦n. Each master key set {mk}i for server Si thus contains a respective master key mki,j common to each other server Sj storing a key-share of the secret key K. The master key mki,j will be known only to servers Si and Sj so that each pair of servers {i,j}{0, . . . , n} will have a common master key that is unknown to other servers.


In step 71, the sets of master keys {mk}i are securely distributed to the other servers Si(i=1 to n) via the secure message transmission functionality Fsmt discussed above.


In step 72, the second server compartment SC20 produces its set of blinding seeds {s}0=(custom-characters{o,j})custom-characterj=1n. Each blinding seed so,j is produced from a respective master key mko,j of the AC server's master key set {mk}0. In this preferred embodiment, each blinding seed so,j comprises a pseudorandom function of a respective master key mko,j.


In step 73, the second server compartment SC20 generates the secret key K and public key L of the key-pair (L, K) for system 1. In step 74, SC20 generates its random share δ0 of zero from its master key set {mk}0. This step, detailed further below, uses the above combinatorial secret sharing technique to compute δ as a combination of pseudorandom functions of respective master keys mko,j. In step 75, SC20 generates the initial key-share K0 for AC server S0 by setting K0←K+δ0.


In step 76, the second server compartment SC20 updates its set of master keys {mk}0 ready for the first epoch of the authentication protocol. (In practice, this step may be performed in conjunction with blinding seed production in step 72 as illustrated by the example to follow). Each updated master key comprises a function of the corresponding initial master key mko,j produced in step 70 above. In this preferred embodiment, the updated master key comprises a pseudorandom function of the initial master key mko,j. The resulting updated master keys constitute the master key set {mk}0=(custom-charactermk{o,j})custom-characterj-1n for the first epoch.


In step 77, SC20 stores its backup data backup0 as backup0←(K0, L, {mk}0=(custom-charactermk{o,j})custom-characterj=1n. In step 78, SC20 supplies the initial key-share K0, the public key L and the set of blinding seeds {s}0 to the first server compartment SC10 as part of the state st0 which is set to st0=(K0, L, {s}0=(custom-characters{o,j})custom-characterj=1n). The initialization of AC server 2 is then complete.



FIG. 7 indicates the initialization procedure for each of the other servers Si, here each authentication server S1 to Sn of system 1. In this process, the server Si receives and stores its set of master keys {mk}i in memory of second server compartment SC2i, and generates its initial key-share Ki and set of blinding seeds {s}i. The initial key-share Ki and blinding seeds {s}i form part of the initial state sti of the first server compartment SC1i of server Si.


In step 80, the second server compartment SC2i receives its set of master keys {mk}i=(custom-charactermk{i,j})custom-characterj=o,j≠in via Fsmt.


In step 81, the second server compartment SC2i produces its set of blinding seeds {s}i=(custom-characters{i,j})custom-characterj=o,j≠n. Each blinding seed si,j is produced from a respective master key mki,j of the server's master key set {mk}i, here as a pseudorandom function of that master key.


In step 82, SC2i generates its random share δi of zero from its master key set {mk}i using the combinatorial secret sharing technique to compute δi as a combination of pseudorandom functions of respective master keys mki,j. This is explained further below. In step 83, SC2i generates the initial key-share Ki for server Si by setting Ki←δi.


In step 84, SC2i updates its set of master keys {mk}i ready for the first epoch in corresponding manner to step 76 above. Each updated master key thus comprises a pseudorandom function of the corresponding initial master key mki,j, and the resulting updated master keys constitute the master key set {mk}i=(custom-charactermk{i,j})custom-characterj=o,j≠in for the first epoch.


In step 85, SC2i stores its backup data backupi as backupi←(Ki, {mk}i=(custom-charactermk{i,j})custom-characterj=o,j≠in). In step 86, SC2i supplies the initial key-share Ki and the set of blinding seeds {s}i to the first server compartment SC1i as part of the state sti:


set initial state of SC1i to sti=(Ki, {s})i=(custom-characters{i,j})custom-characterj=o,j≠in).


The initialization of the authentication server 3 is then complete.



FIG. 8 indicates steps performed by the servers in an authentication operation of this embodiment. The authentication procedure begins in step 90 when the AC server So receives a user's login data (uid, p′) in step 90. In step 91, the first server compartment SC1o produces a hash value h as h=H(uid, p′). In step 92, SC1o computes the blinded hash value u=hN=H(uid, p′)N where N is a random nonce. In step 93, SC1o sends the blinded hash value u to each of the authentication servers S1, . . . , Sn.


The blinded hash value u is received by each authentication server Si (i=1 to n) in step 94. In step 95, the first server compartment SC1i of each authentication server produces a blinding factor βi which comprises a random share of a predetermined value, here unity, which is shared between the servers (here all servers S0 to Sn) storing key-shares Ki. The blinding factor βi is produced from the set of blinding seeds {s}i=(custom-characters{i,j})custom-characterj=0,j≠in which are pseudorandom functions of respective master keys mki,j here. The blinding factor βi thus comprises a function of the master keys {mk}i which are protected by second server compartment SC2i. More specifically here, the blinding factor βi is computed, using the combinatorial secret sharing scheme above, as a combination of pseudorandom functions of respective master keys mki,j via:







β
i







i
=
0

,

i

i


n








B


(

s

[

i
,
j

]


)



Δ

i
,
j








where Δi,j is as defined above, i.e. Δi,j=1 if i<j or Δi,j=−1 otherwise. B here represents a hash function (and may operate on further values, such as a session identifier, in addition to the blinding seed si,j as indicated in the detailed implementation below).


Next, in step 96, the first server compartment SC1i of each authentication server Si produces its hash response vi as a function of the blinded hash value u, that server's key-share Ki, and the blinding factor. In this embodiment, the hash response vi is computed as vi=uKβi. The hash responses vi of each authentication server Si are returned to AC server S0 in step 97.


In step 98, the first server compartment SC10 of AC server S0 computes its own random share β0 of unity as:







β
0






j
=
1

n







B



(
s



[

0
,
j

]


)






where Δi,j =1 here as i=0. In step 99, SC10 then computes v0=uKoβ0 and computes v=F(h, K) as






v
=





i
=
0

n







v
i

1
N



=





i
=
0

n








(


u

K
i


,

β
i


)


1
N



=





i
=
0

n








u


K
i

N


·




i
=
0

n







β
i

1
N





=



H


(

uid
,

p



)



Σ






K
i



=

h
K

















since









i
=
0

n







β
i



=
1.





The blinding factors βi thus combine to cancel in this computation.


In step 100, SC10 computes the input password hash PH′ as PH′=G(uid, p′, v)=G(uid, p′, H(uid, p′)ΣKi)=G(uid, p′, hK).


The subsequent steps 101 to 103 of FIG. 8 correspond respectively to steps 38 to 40 of FIG. 3 in which the input password hash PH′ is compared with the user password hash PH for uid to determine if user access to the resource should be permitted or refused. The user password hash PH is produced in corresponding manner from the user password p registered for uid in a setup operation of this embodiment. The setup operation thus includes steps which correspond generally to steps 90 to 100 above to produce the user password hash PH from the user password p. The setup procedure also includes verification step 52 of FIG. 4 for verifying the function F(h0, K) produced in this procedure. Two examples of this verification step will be described below.


Since the blinding factors βi in the above scheme are random shares of a predetermined value, here unity, these blinding factors can be combined and eliminated in computation of the password hashes PH and PH′. This elegant mechanism allows hash responses to be blinded while preserving the overall result of the protocol and avoiding the need for servers to commit to their key-shares K. This offers security against transient corruptions over arbitrarily many key-refresh procedures as will now be described with reference to FIG. 9.



FIG. 9 indicates steps of the refresh procedure which is performed by all servers S0 to Sn in this embodiment for each successive epoch. In this process, the second server compartment SC2i of each server Si unilaterally generates a new key-share IC, for that server, and updates its master keys {mk}i and blinding seeds {s}i. The servers Si synchronize to refresh simultaneously, e.g., by performing refreshes at regular time intervals, or by agreeing on refresh timing through out-of-band communication.


In step 110 of FIG. 9, the second server compartment SC2i retrieves its backup data backupi, which includes its current key-share Ki and master key-set {mk}i=(custom-charactermk{i,j})custom-characterj=0,j≠1n, from memory. In step 111, SC2i generates a new random share δi of zero from its current master key set {mk}i. This step uses the combinatorial secret sharing technique as before to compute δi as a combination of pseudorandom functions of respective master keys mki,j. In step 112, SC2i generates a new key-share for Si as a combination (in this example a sum) of the current key-share Ki and the new random share δi, i.e. set new key-share Ki←current key-share Kii. The new key-shares Ki of all servers Si are thus independent of those in the previous epoch, but the sum










i
=
0

n







K
i


=
K




remains constant.


In step 113, SC2i updates the master keys {mk}i and blinding seeds{s}i for server Si. The updated blinding seeds {s}i=(custom-characters{i,j})custom-characteri=0,j≠in are produced from respective master keys mki,j of the current master key set {mk}i. In this embodiment, each new blinding seed si,j is produced as a pseudorandom function of a respective master key mki,j. Similarly, each master key is updated as a function, here a pseudorandom function, of that master key mki,j for the preceding epoch. The resulting updated master keys constitute the master key set {mk}i=(custom-charactermk{i,j})custom-characterj=o,j≠in for the new epoch.


In step 114, SC2i updates is backup data backupi to include the new key-share Ki, new set of master keys {mk}i, and new set of blinding seeds {s}i. In step 115, SC2i supplies the new key-share Ki and the new blinding seeds {s}i to the first server compartment SC1i as part of the new state sti for the new epoch. The refresh process is then complete.


The refresh scheme allows key-shares to be unilaterally refreshed by each server, with refresh taking place in a secure environment provided by the second server compartment with access to trusted backup data. The system remains secure against offline dictionary attacks provided that not all A, servers in the system are compromised in the same epoch. Use of a fresh virtual machine for the first server compartment in each epoch conveniently eliminates any contamination of the first compartment due to server compromise in the preceding epoch. The blinding seeds {s}i which are used to compute the blinding factors βi are updated for each epoch, while the master keys {mk}i from which {s}i are calculated are protected by second server compartment SC2i. Moreover, updating of the masters keys {mk}i additionally provides so-called “forward security” in the system. That is, even if the backup data backupi of a server Si were to leak, then the adversary would still be unable to recompute all Si's past key-shares.


An exemplary implementation of the above system is described in detail in the following. In this construction, verification step 52 of FIG. 4 is implemented via a zero knowledge proof. Some preliminaries are described first.


Let κ∈N be a security parameter. A polynomial-time algorithm A is an algorithm that takes κ as an implicit input and that has running time bounded by a polynomial in κ. A function v(κ) is said to be negligible if for every polynomial p(κ) there exists a κ′∈N such that v(κ)<1/p(κ) for all κ>κ′. For concrete security, one could typically use κ=128.


Pseudo-Random Generators. A pseudo-random generator (PRG) is a function PRG:D→R where no polynomial-time adversary can distinguish the output of PRG on a random input from a truly random string. The advantage AdvA.PRGpr(κ) of an adversary A is defined as |Pr[1=A(y):x←kR D,y←PRG(x)]−PR[1=A(y):y←kRR]|.


Message Authentication Codes. A message authentication code (MAC) is a function MAC:κ×{0,1}x→T that on input of a key μ and a message m∈{0,1}x returns a tag T. We say that MAC is unforgeable against chosen-message attack if all polynomial-time adversaries A have negligible advantage AdvA,MACufcma(x) defined as PR[T=MAC(μ, m)custom-characterm∉Q:μ←Rκ; (m, T)←RAMAC(μ, ·), where Q is the set of messages that A submitted to its MAC(μ,·) oracle.


Let G be a multiplicative group of prime order q>22x with generator g. Let H: {0,1}x{0,1}x→G, G:{0,1}x×{0,1}x×G→{0,1}2x, C:Zq→{0,1}2x, B0: {0,1}κ×N→G, B1:{0,1}κ×N→G, B2:{0,1}κ×N→G, and B3:{0,1}κ×N→Zq be hash functions modelled as random oracles. Let PRG:{0,1}κ→{0,1}κ×Zq×{0,1}κ×{0,1}κ be a pseudo-random generator and MAC:{0,1}κ×{0,1}κ→T be a message authentication code.


The protocol below provides AC server S0 were with a shared MAC key μ{0,i} with each server Si, i=1 to n. Whenever the description below says that AC server S0 sends m to Si, this means that S0 computes T←MAC(μ{0,i}, m) and sends (m, T) to Si. Similarly, when Si receives m from S0, this means that Si receives (m, T) and checks that T=MAC(μ{0,i}, m), ignoring the message m if that is not the case. The communication in the other direction from server Si back to S0 is protected in the same way with the same MAC key μ{0,i}. Messages may also include appropriate servers IDs and session IDs which are omitted in the following for simplicity.


The state information sti of each server Si, i=0 to n, contains a list of blinding seeds (custom-characters{i,j})custom-characterj=0,j≠in that are used to generate random shares of the unity element in G or of zero in Zq using the combinatorial secret sharing scheme explained above. In each account creation or login session, the servers Si derive fresh shares ηi,0, . . . , βi,3 of unity or zero using the random oracles B0, . . . , B3 applied to s{i,j} and a sub-session identifier ssid, and use these shares as blinding factors for their protocol messages so that











i
=
0

n







β

i
,
k



=


1





for





k

=
0


,
1
,


2





and









i
=
0

n







β

i
,
z




=

0





mod






q
.







More precisely, Si's blinding factors are computed as









β

i
,
k








j
=
0

,

j

i


n








B
k





(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j








for





k



=
0

,
1
,


2





and





as






β

i
,
z









j
=
0

,

j

i


n




Δ

i
,
j




B
3




(


s



{

i
,
j

}



,
ssid

)






mod





q



,










where






Δ

i
,
j



=



1





if





i

<

j





or






Δ

i
,
j




=


-
1







otherwise
.








Initialization.

During initialization, all servers are uncorrupted and can communicate through the secure message transmission functionality Fsmt.


AC Server S0

  • For all 0≦i<j≦n, choose a master key mk{i,j}R{0,1}κ.
  • For i=1, . . . , n, securely send (custom-charactermk{i,j})custom-characterj=o,j≠in to server Si via Fsmt. For all j=1, . . . , n, compute (mk{0,j}, d{0,j}, s{0,j}, μ{0,j}). The mk{o,j} output by this function constitute the updated master keys of step 76 of FIG. 6. The blinding seeds s{0,j} are thus computed (step 72 of FIG. 6) in the same step since all values mk{0,j}, d{0,j}, s{0,j}, μ{0,j} are taken from different portions of the output space of PRG. Choose master key K←R Zq and set public key L←gK. Compute initial key-share K0←K +δ0 where







δ
0

=




j
=
1

n








d

{

0
,
j

}







mod











q






(where Δi,j=1 here as i=0).

  • Store state st0←(K0, L, (custom-characters{0,j})custom-characterj−1n, (custom-characterη{0,j})custom-characterj=1n and store backup data backup0 ←(K0, L, (custom-charactermk{0,j}j=1n).


Authentication Servers Si.

  • Receive (custom-charactermk{i,j})custom-characterj=o,j≠in from server S0 via Fsmt.
  • For all j=0, . . . , n, j≠i, compute (mk{i,j}, d{i,j}, s{i,j}, μ{i,j})←PRG(mk{i,j}). Compute initial key-share Ki←δi where







δ
i

=





j
=
0

,

j

i


n




Δ

i
,
j




d

{

i
,
j

}







mod





q






and Δi,j as defined above.

  • Store state sti←(Ki, (custom-charactersj{i,j})custom-characterj(j=0,j≠t)tn, (custom-characterμj{i,j})custom-characterj(j=0,≠i)tn) and store backup data backupi←(Ki,(custom-charactermk{i,j})custom-characterj=o,j≠in).


Account Setup.

To create an account for user uid with password p, the AC server S0 runs the following protocol with all n authentication servers S1 to Sn.


AC Server S0. The AC server sends a blinded password hash and a challenge hash to all servers.

  • Generate a random nonce N←R Zq and a random challenge c←R Zq. Compute u=H(uid, p)N and ch=C(c).
  • Send (ssid, u, ch) to all S1 to Sn, where ssid is a sub-session identifier.
  • Store (uid, p, N, u, c) associated with ssid.


Authentication Servers Si. Each server sends a blinded hash response using its secret key-share and the blinded first move of a zero-knowledge proof.













Compute






v
i





?



β

i
,
0




,


where






β

i
,
0



=






j
-
0

,

j

i


n








B
0






(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j



.








Compute







R

1
,
i







g

r
i


·





j
=
0

,

j

i


n








B
1





(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j








and


















R

2
,
i





u

r
i


·





j
=
0

,

j

i


n








B
2





(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j








where






r
i







?



.





?




indicates text missing or illegible when filed







  • Respond by sending (ssid, vi, R1,i, R2,i) to S0.

  • Store (ri, ch) associated with ssid.



AC Server S0. The AC server sends the challenge for the zero knowledge proof.

  • On receiving (ssid, vi, R1,i, R2,i) from all servers S1 to Sn, retrieve (uid, p, N, u, c) associated with ssid.
  • Update the information stored with ssid to (uid, p, N, u, c, (vi, R1,i, R2,i)i=1n)). end (ssid, c) to all servers S1 to Sn.


Authentication Servers Si. Each server checks the challenge hash from the previous round and sends the blinded last move of a zero-knowledge proof.

  • On receiving (ssid, c) from S0, retrieve (r1, ch) associated with ssid. Abort if it does not exist. If C(c)≠ch, abort.







Compute






s
i






K
i


c

+

r
i

+





j
=
0

,

j

i


n








Δ

i
,
j




B
3




(


s



{

i
,
j

}



,
ssid

)






mod






q
.








  • Respond by sending (ssid, si) to S0. Remove all information associated to ssid.



AC Server S0. The AC server verifies the aggregated server responses through the zero knowledge proof and computes the user password hash.

  • On receiving (ssid, si) from all servers S1 to Sn, retrieve (uid, p, N, u, c, (vi, R1,i, R2,i)i=1n) stored for ssid. Abort if it does not exist.







Compute






v
0





u

K
0


·




j
=
1

n








B
0





(


s



{

0
,
j

}



,
ssid

)

.








Choose r0←n Zq, compute







R

1
,
0





g

r
0


·




j
=
1

n








B
1




(


s



{

0
,
j

}



,
ssid

)






and






R

2
,
0








u

r
0


·




j
=
1

n








B
2





(


s



{

0
,
j

}



,
ssid

)

.








Also compute













s
0





K
0


c

+

r
0

+




j
=
1

n








Δ

i
,
j




B
3




(


s



{

0
,
j

}



,
ssid

)






mod






q
.




Compute






v








i
=
0

n







v
i

1
N




,


R
1






i
=
0

n







R

1
,
i




,


R
2






i
=
0

n








R

2
,
i







and





s







i
=
0

n








s
i






mod






q
.









  • Verify that gs=LcR1 and us=vNcR2 and if not abort. This concludes the zero knowledge proof corresponding to verification step 52 of FIG. 4.

  • Store PH=G(uid, p, v) as the user password hash for uid. Remove all information associated to ssid.



User Login

The login protocol is a simplified version of account setup, without zero knowledge proof.


AC Server S0. The AC server sends a blinded hash value to all servers. On receipt of an input password p′ for user uid, generate a random nonce N←R Zq and compute u=H(uid, p′)N. Send (ssid, u) to all S1 to Sn, where ssid is a sub-session identifier. Store (uid, p′, N, u) associated with ssid.


Authentication Servers Si. Each server sends a blinded hash response using its secret key-share.


On receiving (ssid, u) from S0, compute vi=uKi βi,0, where







β

i
,
0








j
=
0

,

j

i


n








B
0






(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j



.







Respond by sending (ssid, vi) to S0.


AC Server S0. The AC server verifies the recomputed input password hash PH′ against the stored user password hash PH.

  • On receiving (ssid, vi) from all servers S1 to Sn, retrieve (uid, p′, N, u) associated to ssid. Abort if it does not exist.







Compute






v
0





u

K
0


·




j
=
1

n








B
0





(


s



{

0
,
j

}



,
ssid

)


Δ

0
,
j








and





v








i
=
0

n








v
i

1
N


.






  • If PH=G(uid, p′, v) then permit user access to the resource. Otherwise refuse access. Delete the stored tuple (uid, p′, N, u) associated to ssid.



Refresh.

Servers Si, i=0 ton. Based on its backup backup, and current state sti, Si computes its new state.

  • If Si=S0, recover backup0=(K0, L, (custom-charactermk{o,j})custom-characterj=1n), and if Si=S1 to Sn, recover backupi=(Ki, (custom-charactermk{i,j})custom-characterj=o,j≠in).
  • For all j=0, . . . , n, j≠i, compute (mk{i,j}, s{i,j}, μ{i,j})←PRG(mk{i,j}) and compute the new key-share Ki←current key-share Kii, where







δ
i

=





j
=
0

,

j

i


n








Δ

i
,
j




d

{

i
,
j

}







mod






q
.







  • If Si=S0, store new backup data backup0=(K0, L, (custom-charactermk{0,j})custom-characterj=1n) and set the new state st0←(K0, L, (custom-characters{0,j})custom-characterj=1n, (custom-characterμ{0,j})custom-characterj=1n).

  • If Si=S1 to Sn, store new backup data backupi←(Ki, (custom-charactermk{i,j})custom-characterj=o,j≠in) and set the new state sti=(Ki, (custom-characters{i,j})custom-characterj−0,j≠in, (custom-characterμ{i,j})custom-characterj=0,j≠in).



The above scheme offers a simple and highly efficient proactively secure password authentication protocol which rules out dictionary attacks unless all servers are corrupted during the same epoch. A corrupt AC server only sees the passwords of user accounts that are created or logged into during the corruption. No passwords, password hashes, or any other offline-attackable information is leaked for accounts that are inactive during the corruption. This provides good protection against “smash-and-grab” attacks and short-term corruptions. Login, i.e., password verification, is a single-round protocol requiring just one exponentiation in a prime-order group on each server (two for the AC server), which is essentially optimal for schemes with public-key operations. The recovery and key refresh procedure is non-interactive and only involves a couple of additions and pseudorandom function evaluations per server, making it more than efficient enough to perform preventively on a regular basis instead of just after a detected breach.


An alternative construction, which is even more efficient, is described in the following. It is almost identical to the construction above except that the zero knowledge proof for implementing verification step 52 of FIG. 4 is replaced by a pairing computation by the AC server.


Let G1, G2, Gt, be multiplicative groups of prime order q with generators g1, g2, gt respectively, and an efficiently computable pairing function e:G1×G2→Gt, Let H:{0,1}x×{0,1}x→G1, G:{0,1}x×{0,1}x×G1→{0,1} and B0:{0,1}κ×N→G1 be hash functions modelled as random oracles. Initialization, login, and refresh are identical to the discrete-logarithm scheme above, except that L←g2κ and that group operations during login take place in G1. Account setup is considerably simpler, as the two-round zero-knowledge protocol is now replaced with a pairing computation.


Account Setup.

To create an account for user uid with password p, the AC server S0 runs the following protocol with all n authentication servers S1 to Sn.


AC Server S0. The AC server sends a blinded password hash to all servers. Compute u=H(uid, p)N and send (ssid, u) to all S1 to Sn. Store (uid, p, N, u) associated with ssid.


Authentication Servers Si. Each server sends a blinded hash response using its secret key-share.













Compute






v
i


=


?



β
i



,


where






β
i








j
=
0

,

j

i


n








B
0





(


s



{

i
,
j

}



,
ssid

)


Δ

i
,
j














?



indicates text missing or illegible when filed





Respond by sending (ssid, vi) to S0.


AC Server S0. The AC server verifies the server contributions and computes the user password hash PH.

  • On receiving (ssid, vi) from all servers S1 to Sn, retrieve (uid, p, N, u) stored for ssid. Abort if it does not exist.







Compute






v
0





u

K
0


·




j
=
1

n







B




(


s



{

0
,
j

}



,
ssid

)


Δ

0
,
j








and





v








i
=
0

n








v
i

1
N


.






  • Verify that e(v, g2)=e(H(uid, p), L). If not, abort.

  • Store PH=G(uid, p, v) as the user password hash for uid. Remove all information associated to ssid.



The above scheme based on bilinear maps offers single-round account setup with one exponentiation per authentication server, and one exponentiation and one pairing computation for the AC server.


Many changes and modifications can of course be made to the exemplary embodiments described above. For example, while the above examples describe n-out-of-n schemes in which all key-shares Ki are used to reconstruct the shared key K, embodiments based on t-out-of-n (threshold) schemes can be envisaged. For instance, Shamir's secret sharing scheme allows a secret key K∈G to be shared among a set of servers S1, . . . , Sn so that any subset of size t can recover K. Shamir's approach underlies almost all practical t-out-of-n threshold cryptography schemes. The dealer (e.g., S1) chooses a random polynomial f(x) of degree t−1 such that f(0)=K, for example, by choosing random coefficients α1, . . . , αt−1R G and letting f(x)=K+α1x+ . . . +αt−1xt−1. The dealer hands Si its key share Ki=f(i). Given t different points (i, Ki) of the polynomial for Si{1, . . . , n}, #S=t, one can use Lagrange interpolation to reconstruct the polynomial as






f(x)=Σi(i∈S)custom-characterΠi(j∈S\{i})custom-character(x−j)/(i−j)icustom-character


and therefore recompute the key K=f(0) as






K
=




i

S









λ

S
,
i




K
i







where λs,i are the Lagrange coeffcients λi(S,i)=Πi(j∈S\{i})custom-characterj(j−i)custom-character.


Various other server implementations can also be envisaged. For example, the data (master keys, etc.) generated by S0 in the above schemes could be written to a secure device such as a smart card, HSM (Hardware Security Module), TPM (Trusted Platform Module) or similar device which is then distributed to the other servers. This device may then also implement the required functionality of the second server compartment SC2i. Embodiments might also be envisaged where the second server compartment SC2i is implemented by a hypervisor controlling operation of one or more virtual machines providing the first server compartment SC1i.


As further examples, the master keys need not be updated for successive epochs in schemes without forward security. In some embodiments, the verification step corresponding to step 52 of FIG. 4 may be omitted. The schemes can also be modified to accommodate shared values which are constants other than unity or zero in calculating the blinding factors and key-shares. In general, functions indicated in blocks of the flow charts may occur out of the order noted in the figures.


The resource protected by access control server 2 may in general comprise any resource to which user access is restricted, e.g. an application, service, data, device, network or any other facility or combination of facilities.


The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.

Claims
  • 1. A system of λ≧2 servers comprising an access control server for communication with user computers via a network and controlling access by the user computers to a resource in dependence on authentication of user passwords associated with respective user IDs, and a set of authentication servers for communication with the access control server via the network, wherein: at least each authentication server stores a respective key-share Ki of a secret key K which is shared between a plurality of the λ servers;the access control server is adapted, in response to receipt from a user computer of a said user ID and an input password, to produce a hash value h via a first hash function operating on the input password, to blind the hash value h to produce a blinded hash value u, and to send the blinded hash value u via the network to at least a subset of the set of authentication servers;each authentication server is adapted, in response to receipt of the blinded hash value u, to produce a hash response vi from the blinded hash value u and that server's key-share and to send the hash response vi via the network to the access control server; andthe access control server is adapted to produce, using the hash response vi from each authentication server, an input password hash comprising a predetermined function of said hash value h and said secret key K, and to compare the input password hash with a corresponding user password hash, produced from said user password for the received user ID and pre-stored by the access control server, to determine whether said input password equals the user password, if so permitting access to the resource by the user computer.
  • 2. A system as claimed in claim 1 wherein the access control server stores a said key-share Ki of the secret key K.
  • 3. A system as claimed in claim 1 wherein the access control server is adapted to send the blinded hash value u to each authentication server of said set.
  • 4. A system as claimed in claim 1 wherein each authentication server is adapted such that said hash response vi comprises a function of the blinded hash value u, that server's key-share Ki, and a blinding factor βi which comprises a random share of a predetermined value which is shared between said plurality of servers storing respective key-shares Ki.
  • 5. A system as claimed in claim 4 wherein said predetermined value equals 1.
  • 6. A system as claimed in claim 5 wherein the hash response vi comprises the function uκiβi.
  • 7. A system as claimed in claim 4 wherein each server Si storing a key-share Ki is adapted to update the key-share Ki for each of successive time periods in operation of the system.
  • 8. A system as claimed in claim 4 wherein each server Si storing a key-share Ki also stores a set of master keys which comprises a respective master key mki,j common to each other server Sj, j≠i, storing a key-share Ki, and wherein said blinding factor βi comprises a function of said set of master keys.
  • 9. A system as claimed in claim 8 wherein more than two servers store respective key-shares Ki and wherein said blinding factor βi comprises a combination of pseudorandom functions of respective master keys.
  • 10. A system as claimed in claim 8 wherein each server Si storing a key-share Ki is adapted to update each master key mkij for each of successive time periods in operation of the system, the updated master key comprising a function of that master key mkij for the preceding time period.
  • 11. A system as claimed in claim 8 wherein each server Si storing a key-share Ki comprises: a first server compartment, connectable to the network, which stores the key-share Ki and a set of blinding seeds, wherein each blinding seed comprises a pseudorandom function of a respective master key mki,j; anda second server compartment, inaccessible from the network in operation of the system, which stores said set of master keys;wherein the second server compartment is adapted to produce each blinding seed from a master mki,j and to supply the blinding seed to the first server compartment, and wherein the first server compartment is adapted to produce said blinding factor βi from the set of blinding seeds.
  • 12. A system as claimed in claim 11 wherein the second server compartment is adapted to update each blinding seed for each of successive time periods in operation of the system, and to supply the set of updated blinding seeds for that time period to the first server compartment.
  • 13. A system as claimed in claim 1 wherein the access control server is adapted to produce the input password hash via a second hash function operating on said predetermined function of the hash value h and secret key K.
  • 14. A system as claimed in claim 1 wherein said secret key K comprises the secret key of a cryptographic key-pair (L, K) where L is the public key of the key-pair, wherein the access control server stores the public key L, and wherein, in a setup operation for a said user ID: the access control server is adapted, in response to initial input of the user ID and associated user password in the setup operation, to produce an initial hash value h0 via said first hash function operating on the user password, to blind the initial hash value h0 to produce a blinded initial hash value u0, and to send the blinded initial hash value u0 via the network to at least a subset of the set of authentication servers;each authentication server is adapted, in response to receipt of the blinded initial hash value u0 in the setup operation, to produce an initial hash response vi0 from the blinded initial hash value u0 and that server's key-share Ki, and to send the initial hash response vio via the network to the access control server; andthe access control server is adapted to produce, using the initial hash response vio from each authentication server, said predetermined function of said initial hash value h0 and said secret key K, to verify correctness the secret key K in that function using said public key L, and to store said user password hash comprising that function.
  • 15. A system as claimed in claim 14 wherein the access control server is adapted to verify correctness the secret key K by communicating with at least said subset of the authentication servers to implement a zero-knowledge proof using the public key L.
  • 16. A system as claimed in claim 14 wherein the access control server is adapted to verify correctness the secret key K by verifying that the public key L and said predetermined function of the initial hash value h0 and secret key K satisfy a bilinear map.
  • 17. A method for controlling access by user computers to a resource in dependence on authentication of user passwords, associated with respective user IDs, at an access control server, the access control server being one of λ≧2 servers including a set of authentication servers and being adapted for communication via a network with the user computers and the set of authentication servers, wherein at least each authentication server stores a respective key-share Ki of a secret key K which is shared between a plurality of the λ servers, the method comprising, at the access control server: in response to receipt from a user computer of a said user ID and an input password, producing a hash value h via a first hash function operating on the input password, blinding the hash value h to produce a blinded hash value u, and sending the blinded hash value u via the network to at least a subset of the set of authentication servers;receiving via the network, from each of at least said subset of the authentication servers, a hash response vi produced from the blinded hash value u and that server's key-share Ki; andproducing, using the hash response vi from each authentication server, an input password hash comprising a predetermined function of said hash value h and said secret key K, comparing the input password hash with a corresponding user password hash, produced from said user password for the received user ID and pre-stored by the access control server, to determine whether said input password equals the user password, and if so permitting access to the resource by the user computer.
  • 18. A server comprising storage, a communications interface, and control logic adapted to configure the server to implement an access control server of a system as claimed in claim 1, wherein said storage stores said user password hash for each user ID.
  • 19. A server comprising storage, a communications interface, and control logic adapted to configure the server to implement an authentication server of a system as claimed in claim 1, wherein said storage stores said respective key-share Ki of said secret key K.
  • 20. A server comprising storage, a communications interface, and control logic adapted to configure the server to implement an authentication server of a system as claimed in claim 4, wherein said storage stores said respective key-share Ki of said secret key K.