The present invention relates to an authentication method for authenticating a target module by a verification module.
As is known, in the Information Technology field, the demand for safe transmission of messages or information among communicating modules either of the hardware (for example, electronic devices) or software type is always increasing.
To this end, cryptography techniques for outgoing messages have been developed for messages or information to be made unreadable by unauthorized persons.
For safer transmission of information, several cryptography methods provide that one of the modules involved in the communication must authenticate itself to its partner before receiving or transmitting any message. In other words, through an authentication protocol, a target module interacts with a verification module to convince the latter of its identity.
For example, several known authentication methods provide for data exchange between the target module and the verification module. These exchanged data are the result of processing that is carried out by each module in accordance with protocols shared by both modules, though often requiring significant computational resources from both modules, thereby slowing down the authentication operation and requiring a lot of time to complete the operation.
The object of the present invention is to provide an improved authentication method compared with the known methods.
This object is achieved by a method of authenticating a first module by or with a second module that includes the steps of generating a first random datum by the second module to be sent to the first module, generating a first number by the first module starting from the first datum and by use of a private key ([s]Q_A; [1/(a+s)]Q1), and generating a second number by the second module to be compared with the first number, so as to authenticate the first module. The step of generating the second number is performed starting from public parameters and is independent of the step of generating the first number.
The characteristics and the advantages of the present invention will be understood from the following detailed description of an exemplary non-limiting embodiment thereof with reference to the annexed
The authentication methods of
Particularly, the prover A and the verifier B can be either hardware modules, i.e., electronic devices, or software modules, i.e., instruction sequences of a program.
For example, the prover A can be a smart card, a plug-in module for use with a computer (for example, a USB data key for plugging into a USB port of a computer), a computer itself, a mobile telephone (cellular phone) or any device requiring to be authenticated.
The verifier B can be, for example, a cell phone or a set-top-box (for example, a pay-TV decoder) requiring to authenticate the smart card being inserted therein for reading the data of a user. Furthermore, the verifier B can be a computer network server enabled to send information to authorized users' computers, or rather it can be another computer requiring to read the data stored in the USB data key.
Preferably, the authentication methods of
Additionally, the method refers to three cyclic groups G1, G2 and G3. For example, it is assumed that G1 and G2 are additive groups, whereas G3 is a multiplicative group. Therefore, for the cyclic groups G1 and G2, there can be defined an addition operation (these groups can be designated as (G1, +) and (G2, +)). On the contrary, for the cyclic group G3, there can be defined a multiplication operation (i.e., this group can be designated as (G3, •)).
For example, G1 and G2 may be the points of an elliptic curve defined on the ground field GF(q) or the extension field GF (qk), whereas G3 can be a subgroup of GF(qk)*, i.e., the multiplicative group of the extension field.
In this case, G1 is a [l]-torsion subgroup of the group G2 and satisfies [l]P=O for all PεG1 where O is the identity element, l is a large prime, and l*cofactor=number of points in G2. Additionally, the value of k is the smallest integer for which l/(qk−1). Both G1 and G3 are of prime order l.
Furthermore, the described embodiments use a bilinear function e( ) that when applied to elements of the groups G1×G2 gives an element of G3 as a result. For example, this bilinear function may be the Tate pairing, known to those skilled in the art and that can be expressed as:
e(.,.)=f(.,.)exp((qk−1)/l) (1)
wherein f( ) is a generic function. The bilinear function e( ) is a map or pairing having the following properties:
e(P+Q,S)=e(P,S)·e(Q,S) (2)
e(P,R+S)=e(P,R)·e(P,S) (3)
e([k]P,R)=e(P,R)k=e(P,[k]R) (4)
wherein P and QεG1, R and SεG2. Further, [k]P represents the scalar multiplication of point P by the integer k, so that [k]P=P+P+ . . . +P k times.
It should be observed that Weil pairing may also be used as the bilinear function. In this case, G1 and G2 are the same subgroup of points in the elliptic curve.
The authentication method of
In other words, the prover A can be associated with an identity ID_A, i.e., a bit string identifying said module. In accordance with the mapping method proposed by Boneh and Franklin, a public key Q_A of prover A can be obtained by applying a suitable hash function, called Map-To-Point, to the identity ID_A, that is:
Q
—
A=Map-To-Point(ID—A) (5)
It should be observed that the identity ID_A and the public key Q_A of prover A is a kind of information available to anyone, i.e., not confidential information.
Furthermore, the prover A can be associated with a Trusted Authority TA provided with its own secret key s or “master” key. This master key s is also a bit string.
Particularly, the Trusted Authority TA applies its own master key s to the public key Q_A in order to generate a private key [s]Q_A for the prover A.
In accordance with
Furthermore, with reference to the Trusted Authority TA, there can be defined:
It should be observed that the verifier B that must authenticate the prover A can either have an identity of its own or not. This verifier B knows the public parameter of the prover A, i.e., the identity ID_A, and can compute the public key Q_A through the function hash Map-To-Point, which is a public one. Furthermore, the verifier B knows the mathematic schemes at the heart of the authentication method.
On the contrary, the verifier B does not know the private parameters of the Trusted Authority TA, i.e., the master key s and, accordingly, it does not know the private key [s]Q_A of prover A.
Particularly, the verifier B uses the public parameters and the schemes to generate an authentication protocol of the challenge/response type.
In the first embodiment of the authentication method of the prover A, it is assumed that the verifier B selects a random integer rεGF(q) and computes a first point U=[r]P to be sent to the prover A. Particularly, the first point U represents the scalar multiplication of point P by the random integer r.
It should be observed that the random integer r is not sent unencrypted to the prover A, but rather it is masked within point U.
In other words, the random number r is confidential information contained in the first point U such as to make secure the verification operation performed by the verifier B. In fact, by knowing the point U and point P one cannot trace the random number r. Therefore, an unauthorized person cannot intrude into the authentication operation by taking the place of verifier B in a fraudulent manner.
This first point U=[r]P is “challenge” information that the verifier B sends to A.
After the first point U=[r] P has been received, the prover A performs a computation involving such point U and its own private key [s]Q_A. Particularly, the prover A computes a first integer v belonging to the group G3:
v=e(U,[s]Q—A) (6)
by applying a generic bilinear function e( ) to the first point U and its own private key [s]Q_A. This integer number v is sent to the verifier B.
It should be observed that the verifier B knows the public parameters Ppub, the identity ID_A (hence, also the public key Q_A=Map-To-Point(ID_A) because the hash function Map-To-Point is public) and the random integer r created by the same.
Therefore, the verifier B can compute a second integer:
n=e(Ppub,[r]Q—A)=e([s]P,[r]Q—A) (7)
and verify whether it coincides with the first number v that had been sent to it by the prover A.
In other words, the verifier B is capable of establishing the identity of prover A if the latter has properly computed the first number v. In fact, the verification performed by B works because based on (4), (6) can be written as:
Advantageously, the verifier B can compute the second integer n while waiting to receive the first number v from prover A. In fact, the computation of the number n only involves public parameters that are directly available and does not involve information processed by prover A.
In other words, the verifier B can perform the operations simultaneously with the prover A, i.e., both modules can run in parallel with a considerable reduction in the time required for the authentication operation.
It should be observed that a variation of this first embodiment provides that prover A sends a number H1(v) to the verifier B that is obtained by applying a known hash function H1 to the first number v.
This hash function H1 performs an irreversible compression on first number v, i.e., number v cannot be traced by applying the hash function H1 in inverse to number H1(v).
This variation decreases the number of bits exchanged between the prover A and the verifier B while simultaneously increasing the safety of the method. In fact, the first number v, being the pairing information, is not directly available to unauthorized observers of the communication.
In accordance with
In this case, the Trusted Authority TA provides, besides the master key s, also first P1 and second Q1 base points having their coordinates in the ground field GF(q). In other words, the base points P1 and Q1 are public parameters that are associated with the Trusted Authority TA, their meaning being understood by those skilled in the art.
Additionally, a further parameter [s] P1 is provided by the Trusted Authority TA as a public parameter.
The prover A is identified by way of its own identity ID_A (a bit string). Furthermore, a further number a can be obtained by said identity ID_A as
a=hash(ID—A) (9)
from which it derives that the public key of the prover A relative to the identity is [a] P1.
The Trusted Authority TA supplies the prover A with the public parameters and a private key corresponding to the identity ID_A equal to [1/(a+s)]Q1. This private key [1/(a+s)]Q1 is stored in a suitable memory of the prover A.
In this case, the algorithm of the authentication method provides the steps:
1) the verifier B generates a random integer r and computes the further first point:
U=[r]([a]P1+[s]P1) (10)
to be sent to the prover A;
2) the prover A computes a further first integer v′:
v′=e(U,[1/(a+s)]Q1) (11)
and sends it to the verifier B;
3) the verifier B verifies that the number v′ is equal to a further second number n′
n′=e(P1,Q1)r (12)
This verification has a positive result in that:
Advantageously, even in this case, the verifier B can compute (12) while waiting for the prover A to compute and send (11).
Furthermore, all modifications and optimizations described for the authentication algorithm mentioned above can be applied to this algorithm.
Obviously, to the authentication method of the present invention, those skilled in the art, aiming at satisfying contingent and specific requirements, may carry out further modifications and variations, all however being contemplated within the scope of protection of the invention, such as defined in the annexed claims.
Number | Date | Country | Kind |
---|---|---|---|
PCT/IT2004/000723 | Dec 2004 | IT | national |
The present invention is a continuation of co-pending U.S. patent application Ser. No. 11/315,633 filed Dec. 22, 2005, which claims priority under the Paris Convention of PCT/IT2004/000723 filed Dec. 23, 2004, both of which applications are incorporated herein by this reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | 11315633 | Dec 2005 | US |
Child | 13735876 | US |