The invention generally relates to a method and apparatus for protecting user privacy, and more particularly to a method and apparatus for protecting user privacy with a pseudonym.
With the development of electronic technologies, electronic medical systems have been widely employed in modern medical organizations so as to maintain and manage the individual information and health records (such as the case history, the testing report, and the like) of users (for example, patients). However, electronic records are vulnerable to theft and dissemination. Accordingly, the security issue of modern electronic medical systems is a matter of great concern.
To improve the security of electronic medical systems, two methods of protecting user privacy have been proposed: anonymization and pseudonymization. The purpose of anonymization is to remove the association between the real identity of a user and his or her health records. In other words, in an anonymization method, no individual information about the user is recorded, and only the health records are kept. In such an anonymization method, the user cannot be traced via the health records, though user privacy may be protected securely. The pseudonymization method has been developed on the basis of the anonymization method. In the pseudonymization method, the association between the real identity of a user and his health records has been removed, and the relationship of correspondence is established between the user's health records and one or more of his pseudonyms. Accordingly, the pseudonymization method provides protection of the user's individual information, as well as traceability of his health records.
Unfortunately, the current pseudonymization method as shown in
First, in consideration of security, privacy or the like, or for the reason that a user may have lost a previously generated pseudonym, he may request generation of a new pseudonym every time he goes to the hospital, or even request generation of multiple different new pseudonyms so that diagnosis and/or treatment may be performed for various diseases in the same hospital. In this case, the pseudonym server D140 in
Secondly, the provision of pseudonymization services is generally distinctly regional, that is, a local pseudonym server and an identity manager can only provide pseudonymization services to medical systems in local hospitals within their service coverage or medical systems employing the same pseudonymization service mechanism. In other words, if a medical system generates a pseudonym for a user, medical systems in different regions or with different pseudonymization mechanisms cannot identify the pseudonym for the same user. Every time the user moves from one region to another new region, he must therefore disclose his real identity to the PIM in this new region before obtaining a pseudonym valid in this new region, and then he uses this pseudonym to be treated at the hospital. This causes much inconvenience to the users.
Thirdly, in some trust-based cases, a user is only willing to disclose his real identity to his own trusted local PIM, rather than to a PIM in another strange region. In this respect, the current pseudonymization method can only be applied in a very limited region.
There is, therefore, a need to provide an improved method and apparatus for pseudonym generation and authentication so as to assist the user in enjoying a cross-regional medical service easily and securely.
It is an object of the invention to provide a method and apparatus for pseudonym generation and authentication with which cross-regional identity identification can be provided.
It is another object of the invention to provide a method and apparatus for pseudonym generation and authentication with which the workload of the server can be alleviated.
To achieve the above objects, the invention provides a method for pseudonym generation in a Personal Identity Manager (PIM). The method comprises the steps of: determining a set of public parameters and a set of private parameters; receiving a user identity IDuser from a user device; generating a prime pseudonym Pprime=<H1(IDuser),H1∂(IDuser)> based on the determined set of private parameters and the IDuser, in which H1 is a one-way hash function, ∂ is a random number selected from a domain Zp, and p is a selected prime number; and transmitting the prime pseudonym Pprime and the set of public parameters to the user device.
With this method, a user is only provided with a prime pseudonym once when he makes an initial registration with the PIM. There is no need to generate multiple pseudonyms for the same user frequently. In this manner, the workload of the PIM may be alleviated with this method.
To achieve the above objects, the invention provides a method for pseudonym generation in a user device. The method comprises the steps of: transmitting a user identity IDuser to a Personal Identity Manager (PIM); receiving a set of public parameters and a prime pseudonym Pprime corresponding to the IDuser from the PIM; and selecting at least two random parameters, and generating a sub-pseudonym Ppseu with the at least two random parameters, the set of public parameters, and the prime pseudonym Pprime.
With this method, the user device may self-generate a sub-pseudonym based on a prime pseudonym obtained from the PIM. Moreover, since the sub-pseudonym is generated by using at least two random parameters, the generated sub-pseudonym masks information about the prime pseudonym very well, and there is no association among multiple sub-pseudonyms being generated. Even if one or more sub-pseudonyms are wiretapped in this case, the wiretapper cannot derive the prime pseudonym of the user inversely with the wiretapped sub-pseudonyms. In this manner, the pseudonym generation mechanism has a high level of security.
To achieve the above objects, the invention provides a method for pseudonym authentication in a third-party device. The method comprises the steps of: receiving a sub-pseudonym Ppseu and an identifier IDserver for identifying a Personal Identity Manager (PIM) from a user device; obtaining a set of public parameters from the PIM based on the identifier IDserver; and authenticating the validation of the sub-pseudonym Ppseu by interacting with the user device on the basis of the set of public parameters.
With this method, any third-party device dependent on or independent of the PIM may authenticate the validation of the sub-pseudonym provided from the user device by interacting with the user device on the basis of the set of public parameters obtained from the PIM. In this manner, the use of the sub-pseudonym is not region-limited anymore. With the above method, a medical system in a hospital within any region may identify the user's sub-pseudonym and may then trace his real identity by using the corresponding PIM which assigns the prime pseudonym to the user.
According to another aspect of the invention, a Personal Identity Manager (PIM) is provided, the PIM comprising: a determining unit configured to determine a set of public parameters and a set of private parameters; a receiving unit configured to receive a user identity IDuser; a generating unit configured to generate a prime pseudonym Pprime=<H1(IDuser),H1∂(IDuser)> based on the set of private parameters and the IDuser, in which H1 is a one-way hash function, ∂ is a random number selected from a domain Zp, and p is a selected prime number; and a transmitting unit configured to transmit the prime pseudonym Pprime to the user device.
According to another aspect of the invention, a user device is provided, the user device comprising: a transmitting unit configured to transmit a user identity IDuser to a Personal Identity Manager (PIM); a receiving unit configured to receive a set of public parameters and a prime pseudonym Pprime corresponding to the IDuser from the PIM; and a generating unit configured to select at least two random parameters and generate a sub-pseudonym Ppseu with the at least two random parameters, the public parameters, and the prime pseudonym Pprime.
According to another aspect of the invention, a third-party device is provided, from which a user may request a service, the third-party device comprising: a receiving unit configured to receive a sub-pseudonym Ppseu and an identifier IDserver for identifying a Personal Identity Manager (PIM) from a user device; a transmitting unit configured to transmit information to the user device; an acquisition unit configured to acquire a set of public parameters from the PIM based on the identifier IDserver; and an authenticating unit configured to authenticate the validation of the sub-pseudonym Ppseu by interacting with the user device via the transmitting unit and the receiving unit on the basis of the set of public parameters.
Other objects and accomplishments together with a more thorough understanding of the invention are apparent from and will be elucidated with reference to the following description and claims taken in conjunction with the accompanying drawings.
The disclosure will be described hereinafter in further detail, by way of example, with reference to the accompanying drawings, in which:
Throughout the drawings, identical reference numerals are understood to refer to similar or corresponding features or functions.
A medical system will be taken as an example so as to describe the method and apparatus for pseudonym generation and authentication according to an embodiment of the invention. However, those skilled in the art will appreciate that the method and apparatus for pseudonym generation and authentication according to the invention is not limited to applications in the hospital, but may equally be applied to other fields where the real identity of a user is to be protected. For example, the method and apparatus for pseudonym generation and authentication may equally be applicable to the fields of cyber shopping, book management, etc.
In
The user device D230 in
Referring to
Setup
The method for pseudonym generation and authentication as shown in
In step S211, the PIM D220 selects basic parameters. Specifically, the PIM D220 first selects two prime numbers p and q, and selects a random number a ∂εZp from a domain of an integer mod p (i.e. a domain Zp). Then, the PIM D220 selects two groups of order q modulo p, G1 and G2, in other words, each selected group G1 and G2 has q finite elements, and the group G1 or G2 is a subset of the domain Zp. The PIM D220 also selects a bilinear map ê:G1×G1→G2 to be used between G1 and G2. Here, a bilinear map ê:G1×G1→G2 refers thereto: for all P,QεG1, ê(P, Q) is an element in the group G2, i.e., ê(P, Q)εG2; and for any a, bεZp, ê(aP, bQ)=ê(P, Q)ab. The PIM D220 then selects a random generator gεG1 from the group G1, and selects two one-way hash functions H1 and H2. The two hash functions may satisfy the conditions H1:{0,1}*→G1 and H2:G2→{0,1}*. In other words, H1 is a first one-way hash function which maps a sequence of 0 and 1 having an arbitrary length (for example, representing a character string) to an element in the group G1, and H2 is a second one-way hash function which maps an element in the group G2 to a sequence of 0 and 1 having an arbitrary length.
After selecting the above basic parameters, in step S213, the PIM D220 selects {g,g∂,G1,G2,ê,H2,p} from the above parameters to form a set of public parameters, and selects ∂ and H1 as a set of private parameters. Here, the set of public parameters {g,g∂,G1,G2,ê,H2p} is published, and any of other devices may obtain the set of public parameters from the PIM D220. Meanwhile, the set of private parameters {∂, H1} is secured privately so that a prime pseudonym Pprime may be securely generated for the user when a registration is made by the user.
Registration
Before the user goes to the hospital for the first time, he may choose to register with a trustworthy local PIM D220 in the registration phase S230 so as to obtain a prime pseudonym.
Specifically, in step S231, the user may send a user identity IDuser identifying his real identity to the PIM D220 in a registration request by using the user device D230 (such as a PDA) that he carries. In step S233, the PIM D220 stores the received IDuser in a user identity database, and generates a prime pseudonym Pprime=<H1(IDuser),H1∂(IDuser)> with the received IDuser and the previously determined set of private parameters {∂, H1}. The prime pseudonym is a binary group in which one term is a first hash value calculated by applying the private first one-way hash function H1 to IDuser, and the other term is the first hash value to the power of ∂. Then, in step S235, the PIM D220 sends the generated prime pseudonym Pprime along with the set of public parameters to the user device D230 as a response indicating successful registration. In step S237, the user device D230 stores the received prime pseudonym Pprime and the set of public parameters so that a corresponding sub-pseudonym may be generated in the future as desired. Then, the registration process ends.
Sub-pseudonym Generation
To prevent the PIM D220 from generating pseudonyms for the user frequently in the embodiment shown in
Specifically, in step S251, the user device D230 selects, for example, two random numbers k1,k2εZp from the domain Zp based on the stored set of public parameters. Then, in step S253, the user device D230 generates a sub-pseudonym with the two selected random numbers, the set of public parameters and the prime pseudonym Pprime. In this step, the user device D230 may first calculate the following parameters:
QA=H1k
QB=gk
cA=ê(QC,QD),
in which QC=gk
QD=H1∂k
in which k2−1 is the inverse of the random number k2, that is, k2k2−1 mod p=1.
Then, the user device D230 generates a sub-pseudonym Ppseu=<QA, QB, cA> containing three terms based on the above calculated parameters.
With the above steps S251˜S253, the user device D230 may self-generate different sub-pseudonyms by selecting different random numbers k1,k2εZp. Here, information about the prime pseudonym is securely hidden in the sub-pseudonym because random numbers k1,k2εZp are used for sub-pseudonym generation. It would be difficult for others to calculate information about the prime pseudonym through an inverse calculation based on the stolen sub-pseudonym. Moreover, since k1 and k2 are selected randomly, there will be no associated characteristics among several sub-pseudonyms generated by the same user device D230. In this manner, even if sub-pseudonyms generated by the user device D230 are stolen by others, it is impossible to derive the prime pseudonym assigned by the PIM to the user device based on these sub-pseudonyms. The user may thus safely use the sub-pseudonym generated for him.
Furthermore, while two random numbers are used for sub-pseudonym generation in this embodiment, those skilled in the art will appreciate that it is possible to generate a sub-pseudonym with more than two random parameters in a well-calculated design. Therefore, the invention is not limited to two random numbers as indicated in this embodiment.
Sub-pseudonym Authentication
Every time the user goes to the hospital, he will use the generated sub-pseudonym so as to register in the medical system of the hospital. In phase S270, the medical system D210 of the hospital will first authenticate the validation of the sub-pseudonym provided by the user device D230, that is, authenticate whether the sub-pseudonym is generated on the basis of the prime pseudonym assigned to the user by the PIM so as to ensure that the user's real identity may be traced from the corresponding PIM.
As shown in
The authentication process in step 273 may be implemented in various manners. For example, when the user trusts the medical system D210 (for example, a local medical system) completely, the medical system D210 may take a prime pseudonym from the user device D230. After a prime pseudonym has been obtained from the user device D230, the medical system D210 may authenticate that the sub-pseudonym is generated in accordance with the prime pseudonym and that the prime pseudonym is assigned by the PIM D220 identified by IDserver, based on the prime pseudonym and the sub-pseudonym provided by the user. More preferably, in step S273, the medical system D210 may authenticate the sub-pseudonym by exchanging zero-knowledge proofs with the user device D230. Since it is not necessary for the user device D230 to reveal information about its prime pseudonym to the medical system D210 in the zero-knowledge proof exchange process, the method is more secure. Exchange of zero-knowledge proofs may also be implemented in various manners.
As shown in
Challenge=<gt,Kses⊕H2(OBtcAt),Enc(Kses,Na)>,
in which OB=ê(g∂,QA).
In this query message, the first term gt carries information about the random number t, the second term Kses⊕H2(OBtcAt) is equivalent to an encrypted session key, and the third term Enc(Kses,Na) represents an encrypted content obtained by encrypting the query content Na with the original session key Kses. Then, in step S375, the medical system D210 sends the query message to the user device D230 and waits for a reply from the user device D230.
In step S376a , upon receipt of the query message, the user device D230 calculates a session key K*ses from the query message with the following equation:
K*ses=Kses⊕H2(OBtcAt)⊕H2(ê(gt,(H1∂(IDuser))k
in which ⊕ represents an XOR operation.
It can be seen from the above equation that the term Kses⊕H2(OBtcAt) on the right of the equation is an encrypted session key included in the query message, and the term H2(ê(gt,(H1∂(IDuser))k
In step S378, upon receipt of the response message, the medical system D210 decrypts the received response message Enc(K*ses,Nb) with the original key K*ses so as to obtain the decrypted response content Nb*. In step S379, the medical system D210 determines whether the above predetermined rule is met between the decrypted response content Nb* and the original content Na. For example, the medical system D210 determines whether Nb* is equal to Na+1 in this embodiment. As described above, if the user device D230 can calculate the original session key correctly, that is K*ses=Kses then the medical system D210 can decrypt Nb*=Nb=Na+1 correctly with the original session key Kses. In other words, the predetermined rule is met between the decrypted response content Nb* and the query content Na. If it is determined in step S379 that the predetermined rule is met between the response content Nb* and the query content Na, it means that the sub-pseudonym of the user device D230 is valid. Equivalently, it is proved that the sub-pseudonym is generated on the basis of the prime pseudonym assigned by the PIM identified by IDserver.
With the above authentication, if the sub-pseudonym is authenticated to be valid, the user has made a successful registration in the medical system D210. Then he may go to the hospital with the sub-pseudonym, and his health records may be stored and managed in the name of the sub-pseudonym Ppseu=<QA, QB, cA>.
In the above authentication process, the sub-pseudonym of the user device D230 to be authenticated as valid has the precondition that the user device D230 has obtained information about the prime pseudonym Pprime=<H1(IDuser),H1∂(IDuser)> assigned by the PIM D220. Since the set of private parameters ∂ and H1 is private here, and the first hash function H1 is one-way, other unauthorized users cannot calculate the prime pseudonym Pprime=<H1(IDuser),H1∂(IDuser)> inversely based on the sub-pseudonym and the set of public parameters with no knowledge of ∂ and H1. Therefore, the authentication result obtained by zero-knowledge proof exchange in steps S373˜S379 is both reliable and secure.
Reverting to
Although the sub-pseudonym provided from the user device D230 is authenticated by the medical system D210 in the embodiment shown in
User Identity Tracing
Referring again to
When the real identity of the user is desired, the medical system D210 sends the sub-pseudonym Ppseu=<QA, QB, cA> provided by the user device D230 to the PIM D220 in step S291 in the embodiment shown in
∀IDuserεDB:ê(QB,H∂(ID′user))?=Ver.
If an ID′user is found to meet the above equation with the query parameter Ver, the resulting IDuser is taken as the real identity of the user corresponding to the sub-pseudonym sent from the medical system D210. Finally, in step S297, the PIM D220 returns the resulting ID′user to the medical system D210 of the hospital. The medical system D210 may therefore contact the user in a timely manner based on the real identity of the user obtained from the PIM D220 when it is needed.
In the above tracing process, a user identity IDuser corresponding to the sub-pseudonym may be found by traversing the user identities in the database. Even if the PIM D220 does not store a prime pseudonym corresponding to the user identity IDuser in the embodiments of the invention, the corresponding real identity of the user may thus be found according to the sub-pseudonym from the medical system D210. This mechanism reduces the workload on the PIM D220 while decreasing its cost. Of course, the tracing method of the invention is not limited to this case, and other alternative methods may be used to find the user identity.
A method for pseudonym generation and authentication according to an embodiment of the invention has been described above in detail with reference to
As shown in
On the one hand, the receiving unit 510 shown in
On the other hand, the receiving unit 510 receives a sub-pseudonym Ppseu (message M7) from the medical system D210 of the hospital. As shown in
On the one hand, the transmitting unit 640 shown in
On the other hand, after the transmitting unit 64O sends the sub-pseudonym Ppseu=<QA, QB, cA> to the medical system D210, the medical system D210 may authenticate the validation of the sub-pseudonym. For example, the receiving unit 610 in
K*ses=Kses⊕H2(OBtcAt)⊕H2(ê(gt,(H1∂(IDuser))k
The calculated session key K*ses is fed into the decrypting unit 654. The decrypting unit 654 decrypts the encrypted content Enc(Kses, Na) in the query message with the calculated session key K*ses so as to obtain a decrypted content Na*. The decrypted content Na* is fed into the encrypting unit 656. The encrypting , unit 656 selects a response content Nb corresponding to the decrypted content Na* in accordance with a predetermined rule, and encrypts the response content Nb with the calculated session key K*ses so as to obtain a response message Enc(K*ses, Nb). The response message Enc(K*ses, Nb) (message M6) may be transmitted via the transmitting unit 640 to the medical s stem D210 for authentication. Here, the authenticating nun may be implemented in many other mariners, and is not limited to the configuration shown in
As shown in
Specifically, the selecting unit 741 in the authenticating unit 740 selects a random number tεZp, an original session key Kses, and a query content Na, for generating a query message. The original session key Kses is used to encrypt the query content Na so as to obtain an encrypted content Enc(Kses, Na). Based on the selected parameter selected by the selecting unit 741, the sub-pseudonym, and the set of public parameters, the query message generating uint 743 generates a query message <gt, Kses⊕H2(OBtcAt), Enc(Kses, Na)>, and sends the query message (message M5) to the use device D230 via the transmitting unit 750. Then, after receiving the response message Enc(K*ses, Nb) (Message M6) from the user device D230, the receiving unit 710 sends the response message to the authenticating unit 740. The decrypting unit 745 in the authenticating unit 740 decrypts the response message Enc(K*ses, Nb) with the original session key Kses. The determining unit 747 determines whether the predetermined rule is met between the decrypted response content Nb* and the query content Na, and determines that the sub-pseudonym Ppseu is authenticated to he valid when the predetermined rule is met.
Specific embodiments of the invention have been described above with reference to
Moreover, in the embodiments described above, the medical system D210 of the hospital may authenticate the user-generated sub-pseudonym by interacting with the user device D230 on the basis of a set of public parameters obtained from the PIM D220. In this manner, the user-generated sub-pseudonym may be used in hospitals within different regions, and a cross-regional pseudonym service may thus be implemented.
Additionally, in the embodiments described above, the PIM D220 may find a corresponding user identity by traversing the IDuser stored in the database for a corresponding user identity based on the sub-pseudonym provided by the medical system D210. In this manner, the PIM D220 has no need to store the prime pseudonym for each user, which further decreases the database requirements for the PIM D220 and thus decreases its cost.
Specific embodiments of the invention have been described above with reference to the accompanying drawings. It is to be noted that the above embodiments are intended to illustrate, rather than to limit the invention. It is to be understood by those skilled in the art that various improvements and modifications may be made to the apparatus and method of the invention without departing from the basis of the invention, the scope of which is to be defined by the attached claims. Moreover, any reference numeral in a claim shall not be construed as limiting the claim.
Number | Date | Country | Kind |
---|---|---|---|
2008 1 0169374 | Oct 2008 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB2009/054498 | 10/13/2009 | WO | 00 | 4/13/2011 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2010/044056 | 4/22/2010 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6886096 | Appenzeller et al. | Apr 2005 | B2 |
7587368 | Felsher | Sep 2009 | B2 |
8495372 | Bailey et al. | Jul 2013 | B2 |
20020174073 | Nordman et al. | Nov 2002 | A1 |
20030081785 | Boneh et al. | May 2003 | A1 |
20050193198 | Livowsky | Sep 2005 | A1 |
20080157927 | Soppera et al. | Jul 2008 | A1 |
Number | Date | Country |
---|---|---|
03017559 | Feb 2003 | WO |
Entry |
---|
Lysyanskaya, “Pseudonym Systems,” MIT Laboratory for Computer Science, Mar. 3, 1999, pp. 1-15. |
Lysyanskaya, “Pseudonym Systems,” MIT, A.B., Computer Science and Mathematics, Department of Electrical Engineering and Computer Science, Jun. 1999, pp. 1-52. |
Reischi et al: “Pharmacogenetic Research and Data Protection-Challenges and Solutions”; The Pharmaceutical Journal, 2006, vol. 6, pp. 225-233. |
Claerhout et al: “Privacy Protection for Clinical and Genomic Data: The Use of Privacy-Enhancing Techniques in Medicine”; International Journal of Medical Informatics, 2005, Vo. 74, pp. 257-265. |
Riedl et al: “A Secure Architecture for the Pseudonymization of Medical Data”; Second International Conference on Availability, Reliability and Security (ARES'07), IEEE 2007, 7 Page Document. |
Huang, D.:Pseudonym-Based Cryptopgraphy for Anonymous Communications in Mobile Ad Hoc Networks'; International Journal of Security and Networks; vol. 2, No. 3-4, 2007, pp. 272-283. |
Chen et al: “Applications of Multiple Trust Authorities in Pairing Based Cryptosystems”; Lecture Notes in Computer Science, vol. 2437, Jan. 2002, pp. 260-275. |
Menezes et al: “Handbook of Applied Cryptology”; Chapter 10: “Identification and Entity Authentication”; pp. 385-424, 1997. |
Number | Date | Country | |
---|---|---|---|
20110202767 A1 | Aug 2011 | US |