The disclosure relates to network communication, and in particular, to a method and system for generating a session key, and a communication device.
In order to manage the public key effectively and certify the attribution relation between the owners of the public key and the public-private key pair, a digital certificate mechanism is applied. In the current network security, the Public Key Infrastructure (PKI) system uses a digital certificate mechanism to perform public key management. A Certification Authority (CA) organization responsible for issuing the public key certificate exists in the PKI system. The operation of the PKI system needs to be supported by a hierarchical CA and an online running certificate repository. The online running of the certificate repository occupies network bandwidth. Massive key management reduces the system performance, and gradually becomes a more and more noticeable problem of network security.
Currently, the key is bound to the key owner identifier in two modes. The first mode is: The key owner identifier is generated through the key. The Cryptographically Generated Address (CGA) is typical of this mode. The second mode is: The key corresponding to the identifier is determined through the identifier, namely, Identifier-Based Cryptography (IBC). There is a new public key management system—Identity-Based Encryption (IBE). In the IBE, the public key is not necessarily obtained from the public key certificate repository that runs online. Instead, a string, indicative of the user identity such as name, email address, and IP address, is used as a public key directly. The IBE needs no public key certificate or the relevant operation, thus simplifying the use and management of the public key.
For example, in the IBE-based security email system currently, the email account of the user or a derivative thereof may serve as a public key of the user. Generally, the account of the user is constant in a long term, and the corresponding public key does not change. Therefore, for two users who communicate frequently, the key used by them for encrypting the email does not change. Generally, if a key remains unchanged in a long term, the security of the key is reduced.
In the prior art, a Combined Public Key (CPK) cryptography is also provided. The CPK is also an identifier-based key management system, and is based on Public Key factor Matrixes (PKMs) and Secret/private Key factor Matrixes (SKMs). In this solution, a trustworthy key management center exists, which is responsible for generating PKMs and SKMs. The PKMs are open in the system, and the SKMs are in the custody of the key management center.
The key management center calculates the factors that constitute the private key of the user according to the user identifier and a mapping algorithm, calculates the private key of the user according to the private key factors, and delivers the private key together with the system parameters and the PKM to the user securely.
Afterward, according to the determined PKM, the communicating party calculates the public key of each user according to the user identifier and the corresponding mapping algorithm. For example:
Both parties to a communication calculate the shared key according to the public key of the user, the private key of each party, and the corresponding key exchange algorithm (such as the Diffie-Hellman key exchange algorithm based on the discrete logarithm and the elliptic curve). The calculation based on the following assumptions: Both parties to the communication are A and B, the key exchange algorithm based on the discrete logarithm is applied, and the system parameter is (p, g), where p is a prime number, g is a generator of the finite field Fp, and g is smaller than p.
Party A and party B may calculate the public key of the opposite party according to the corresponding mapping algorithm and the PKM, and may calculate a shared key according to the key exchange algorithm and their own private key.
In the process of implementing the disclosure, it may be found that, when both communication parties use their own private key and the public key of the opposite party to calculate the corresponding shared key, the calculated shared key keeps unchanged in a long term. That is because the public key and the private key for calculating the shared key of both parties remain unchanged in the long term, the identifier of the communication entity decides their corresponding public-and-private key pair, and the identifier of the communication entity remains unchanged in a long term.
Considering that the security in the identity-based combined key management system in the prior art is low because the calculated shared key remains unchanged in the long term, a method and system for generating a session key, and a communication device are provided in various embodiments of the disclosure. The technical solution is as follows.
A method for generating a session key is provided in an embodiment of the disclosure. cryptosystem, the method includes: selecting, by a first communication party, a first temporary private key, operating at least the first temporary private key according to parameters of the cryptosystem, and sending a first message to a second communication party; and operating at least a second message and the first temporary private key according to the parameters of the cryptosystem to generate the first session key after receiving the second message, where the second message is generated by the second communication party after at least the second temporary private key selected by the second communication party is operated according to the parameters of the cryptosystem.
A system for generating a session key is provided in an embodiment of the disclosure. The system is a cryptosystem, and includes: a key management center adapted to generate a long-term public key and a long-term private key according to the parameters of the cryptosystem, and send the long-term private key to the first communication device securely; and first communication device of a first communication device adapted to select a temporary private key; operate at least the temporary private key according to the parameters of the cryptosystem to generate a local message; send the local message to a second communication device of a second communication device; operate at least the received opposite message and the temporary private key according to the parameters of the cryptosystem to generate a session key, where the opposite message is generated by the second communication device after at least the temporary private key selected by the second communication device is operated according to the parameters of the cryptosystem.
A communication device is provided in an embodiment of the disclosure. Based on a cryptosystem, the communication device includes: a temporary private key selecting unit adapted to select a temporary private key; a message generating and sending unit adapted to: operate at least the temporary private key selected by the temporary private key selecting unit according to parameters of the cryptosystem to generate a local message, and send the local message to the opposite communication device; and a session key generating unit, adapted to: operate at least the received opposite message and the temporary private key selected by the temporary private key selecting unit according to the parameters of the cryptosystem to generate a session key, where the opposite message is generated by the opposite communication device after at least the temporary private key selected by the opposite communication device is operated according to the parameters of the cryptosystem.
The technical solution under the disclosure brings the following benefits: The session key, generated after the communication party selects a temporary private key, is variable, thus avoiding too much dependence on the key management center and improving the practicability and security of the key.
The disclosure is detailed below by reference to accompanying drawings and exemplary embodiments, but the disclosure is not limited to the embodiments disclosed herein.
In the identifier-based key management system provided in an embodiment of the disclosure, the communication party selects its own temporary private key to generate a session key through message exchange. Therefore, it is avoided that the shared key remains unchanged in a long term and the communication entity depends on the key management center excessively.
This embodiment supposes that both parties communicate with each other. In the identifier-based key management system, the PKM of the system is the PKM in the prior art, and the SKM of the system is the SKM in the prior art; party A and party B to the communication have their own private key (the private key is generated by the private key management center, and distributed to the corresponding communication entity securely) and public parameters of the system (including PKM); party A and party B may calculate out the long-term public key of the opposite party according to the identifier of the opposite party and the PKM of the system. That is, the user name is mapped according to a mapping algorithm to obtain N mapping value, and then the public key of the user is calculated out in the combined mode.
The communication party may be a communication device or communication terminal.
The method for generating the session key between party A and party B includes:
Step 101: The key management center generates the long-term private key “a” of party A, long-term private key “b” of party B, long-term public key of party A: PA=ga mod p, and long-term public key of party B: PB=gb mod p, and sends a and b to party A and party B, respectively, in a secure mode.
Step 102: Party A selects a temporary private key “x” randomly, and stores it secretly.
Step 103: Party B selects a temporary private key “y” randomly, and stores it secretly.
Step 104: Party A calculates MAB=(PB) ax mod p=gabx mod p, and sends the message MAB to party B.
Step 105: Party B calculates MBA=(PA)by mod p=gaby mod p, and sends the message MBA to party A.
Step 106: After receiving the message MBA sent by party B, party A calculates the session key KA.
K
A=(MBA)X mod p=(gaby mod p)x mod p=gabxy mod p.
Step 107: After receiving the message MAB sent by party A, party B calculates the session key KB.
K
B=(MAB)y mod p=(gabx mod p)y mod p=gabxy mod p.
Therefore, the session key of party A and party B is K=KA=KB.
In this embodiment, there is no limitation to the sequence of steps 102, 103, 104, 105, 106, and 107. These steps may be executed in a rearranged sequence or executed simultaneously.
The method for generating the session key between party A and party B includes:
Step 201: The key management center generates the long-term private key “a” of party A, long-term private key “b” of party B, long-term public key of party A: PA=a*G mod p, and long-term public key of party B: PB=b*G mod p, and sends a and b to party A and party B, respectively, in a secure mode.
Step 202: Party A selects a temporary private key “x” randomly, and stores it secretly.
Step 203: Party B selects a temporary private key “y” randomly, and stores it secretly.
Step 204: Party A calculates MAB=a*x*(PB) mod p=a*x*(b*G) mod p, and sends the message MAB to party B.
Step 205: Party B calculates MBA=b*y* (PA) mod p=b*y*(a*G) mod p, and sends the message MBA to party A.
Step 206: After receiving the message MBA sent by party B, party A calculates the session key KA.
K
A=(MBA)x mod p=x*(b*y*(a*G) mod p) mod p=abxy*G mod p.
Step 207: After receiving the message MAB sent by party A, party B calculates the session key KB.
K
B=(MAB)y mod p=y*(a*x*(b*G) mod p) mod p=abxy*G mod p.
Therefore, the session key of party A and party B is K=KA=KB.
In this embodiment, there is no limitation to the sequence of steps 202, 203, 204, 205, 206, and 207. These steps may be executed in a rearranged sequence or executed simultaneously.
The method for generating the session key between party A and party B includes:
Step 301: The key management center generates the long-term private key “a” of party A, long-term private key “b” of party B, long-term public key of party A: PA=ga mod p, and long-term public key of party B: PB=gb mod p, and sends a and b to party A and party B, respectively, in a secure mode.
Step 302: Party A selects a temporary private key “x” randomly, and stores it secretly.
Step 303: Party B selects a temporary private key “y” randomly, and stores it secretly.
Step 304: Party A calculates MAB=gx mod p and s=(PB) a mod p=gab mod p, and uses s to generate the Message Authentication Code (MAC) of the message MAB, namely, MAC (MAB). Party A sends the message MABand the MAC (MAB) to party B.
Step 305: Party B calculates MBA=gy mod p and s=(PA) b mod p=gab mod p, and uses s to generate the MAC of the MBA, namely, MAC (MBA). Party B sends the message MBA and the MAC (MBA) to party A.
Step 306: After receiving the message MBA sent by party B, party A checks integrity of the MBA according to the MAC (MBA). If the integrity check succeeds, party A calculates the session key KA.
KA=(MBA)a*(PB)x mod p=(gay mod p)*(gbx mod p) mod p=gay+bx mod p.
Step 307: After receiving the message MAB sent by party A, party B checks integrity of the MAB according to the MAC (MAB). If the integrity check succeeds, party B calculates the session key KB.
KB=(MAB)b*(PA)y mod p=(gbx mod p)*(gay mod p) mod p=gay+bx mod p.
Therefore, the session key of party A and party B is K=KA=KB.
In this embodiment, there is no limitation to the sequence of steps 302, 303, 304, 305, 306, and 307. These steps may be executed in a rearranged sequence or executed simultaneously.
The method for generating the session key between party A and party B includes:
Step 401: The key management center generates the long-term private key “a” of party A, long-term private key “b” of party B, long-term public key of party A: PA=a*G mod p, and long-term public key of party B: PB=b*G mod p, and sends a and b to party A and party B in a secure mode respectively.
Step 402: Party A selects a temporary private key “x” randomly, and stores it secretly.
Step 403: Party B selects a temporary private key “y” randomly, and stores it secretly.
Step 404: Party A calculates MAB=x*G mod p and s=a*(PB) mod p=ab*G mod p, and uses s to generate the MAC of the MAB, namely, MAC (MAB). Party A sends the message MAB and the MAC (MAB) to party B.
Step 405: Party B calculates MBA=y*G mod p and s=b*(PA) mod p=ab*G mod p, and uses s to generate the MAC of the MBA, namely, MAC (MBA). Party B sends the message MBA and the MAC (MBA) to party A.
Step 406: After receiving the message MBA sent by party B, party A checks integrity of the MBA according to the MAC (MBA). If the integrity check succeeds, party A calculates the session key KA.
K
A=(a*(MBA)+x*PB) mod p=(ay+bx)*G mod p.
Step 407: After receiving the message MAB sent by party A, party B checks integrity of the MAB according to the MAC (MAB). If the integrity check succeeds, party B calculates the session key KB.
K
B=(b*(MAB)+y*PA) mod p=(bx+ay)*G mod p.
Therefore, the session key of party A and party B is K=KA=KB.
In this embodiment, there is no limitation to the sequence of steps 402, 403, 404, 405, 406, and 407. These steps may be executed in a rearranged sequence or executed simultaneously.
In the foregoing embodiment, the process of generating a session key generally involves use of these parameters: long-term private key of the communication party, public key of the opposite party (inclusive of the long-term private key of the opposite party), temporary private key of the communication party, and the message generated by the opposite party (inclusive of the temporary private key of the opposite party). However, the generation of the session key is not limited to the foregoing method. Here is another exemplary method:
(1) Party A generates a message MAB through calculation according to the temporary private key “x” and the long-term private key “a”, for example, MAB=gax mod p, and sends the message to party B. Likewise, party B generates a message MBA through calculation according to the temporary private key “y” and the long-term private key “b”, for example, MBA=gby mod p, and sends the message to party A.
After receiving the message MBA sent by party B, party A calculates KA=(MBA)ax mod p=gabxy mod p according to the message MBA, the long-term private key “a” and the temporary private key “x”.
After receiving the message MAB sent by party A, party B calculates KB=(MAB)by mod p=gabxy mod p according to the message MAB, the long-term private key “b” and the temporary private key “y”.
(2) Party A generates a message MAB through calculation according to the temporary private key “x”, long-term private key “a”, and long-term public key of party B (namely, PB), for example, MAB=(PB)ax mod p=(gb mod p)ax=gabx mod p, and sends the message to party B. Likewise, party B generates a message MBA through calculation according to the temporary private key “y”, long-term private key “b”, and long-term public key of party A (namely, PA), for example, MBA=gaby mod p, and sends the message to party A.
After receiving the message MBA sent by party B, party A calculates KA=(MBA)ax mod p=gabxy mod p according to the message MBA and the temporary private key “x”.
After receiving the message MAB sent by party A, party B calculates KB=(MAB)by mod p=gabxy mod p according to the message MAB and the temporary private key “y”.
The communication device includes: a temporary private key selecting unit adapted to select a temporary private key; a message generating and sending unit adapted to: operate at least the temporary private key selected by the temporary private key selecting unit according to parameters of the cryptosystem to generate a local message, and send the local message to the opposite communication device; and a session key generating unit adapted to: operate at least the received opposite message and the temporary private key selected by the temporary private key selecting unit according to the parameters of the cryptosystem to generate a session key, where the opposite message is generated by the opposite communication device after at least the temporary private key selected by the opposite communication device is operated according to the parameters of the cryptosystem.
The communication device in this embodiment may select a temporary private key randomly, and the opposite communication device may also select the temporary private key randomly.
The system may be a cryptosystem based on the discrete logarithm or based on the elliptic curve. Moreover, the long-term public key generated by the key management center is obtained from mapping according to the identifier of the communication device.
This embodiment supposes that the cryptosystem is a cryptosystem based on the discrete logarithm. Two communication devices “A” and “B” exist in the system. The system parameter T={g, p}, where p is a prime number, g is a generator of the finite field Fp, and g is smaller than p.
The key management center generates the long-term private key “a” of party A, long-term private key “b” of party B, long-term public key of party A: PA=ga mod p, and long-term public key of party B: PB=gb mod p, and sends a and b to party A and party B in a secure mode respectively.
Party A selects the temporary private key “x” randomly through the temporary private key selecting unit, and stores it secretly. Party B selects the temporary private key “y” randomly through the temporary private key selecting unit, and stores it secretly.
Party A calculates MAB=gx mod p through the message generating and sending unit, and sends a message MAB to party B.
Party B calculates MBA=gy mod p through the message generating and sending unit, and sends a message MBA to party A.
After receiving the message MBA sent by party B, party A calculates the session key KA through the session key generating unit.
K
A=(MBA)a*(PB)x mod p=(gay mod p)*(gbx mod p) mod p=gay+bx mod p.
After receiving the message MAB sent by party A, party B calculates the session key KB through the session key generating unit.
K
B=(MAB)b*(PA)y mod p=(gbx mod p)*(gay mod p) mod p=gay+bx mod p.
Therefore, the session key of party A and party B is K=KA=KB.
In order to enhance security, as shown in
The communication device in this embodiment may select a temporary private key randomly, and the opposite communication device may also select the temporary private key randomly. Besides, the cryptosystem may be a cryptosystem based on the discrete logarithm or based on the elliptic curve.
The technical solution provided in the foregoing embodiments may be implemented through software codes. The software codes may be stored in a computer-readable physical media such as compact disks and hard disks.
In the identifier-based combined key management system in the foregoing embodiments, the session key generated through the temporary private key selected by both communication parties is variable, thus avoiding too much dependence on the key management center, improving the security, and making the identifier-based combined key management method more practicable.
Moreover, a MAC is generated to verify the message integrity, thus further improving the system security.
Although the disclosure has been described through several exemplary embodiments, the disclosure is not limited to such embodiments. It is apparent that those skilled in the art can make various modifications and variations to the disclosure without departing from the spirit and scope of the disclosure. The disclosure is intended to cover the modifications and variations provided that they fall in the scope of protection defined by the following claims or their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
200710087225.5 | Mar 2007 | CN | national |
This application is a continuation of International Patent Application No. PCT/CN2008/070385, filed on Feb. 29, 2008, which claims the benefit of priority to Chinese Patent Application No. 200710087225.5, filed with the Chinese Patent Office on Mar. 21, 2007, and entitled “METHOD AND SYSTEM FOR GENERATING SESSION KEY, AND COMMUNICATION DEVICE”, the contents of both of which are incorporated herein by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2008/070385 | Feb 2008 | US |
Child | 12473371 | US |