US7363492B2 - Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices - Google Patents
Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices Download PDFInfo
- Publication number
- US7363492B2 US7363492B2 US11/066,639 US6663905A US7363492B2 US 7363492 B2 US7363492 B2 US 7363492B2 US 6663905 A US6663905 A US 6663905A US 7363492 B2 US7363492 B2 US 7363492B2
- Authority
- US
- United States
- Prior art keywords
- matrix
- verifier
- prover
- authentication
- masked
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Fee Related, expires
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3218—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using proof of knowledge, e.g. Fiat-Shamir, GQ, Schnorr, ornon-interactive zero-knowledge proofs
- H04L9/3221—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using proof of knowledge, e.g. Fiat-Shamir, GQ, Schnorr, ornon-interactive zero-knowledge proofs interactive zero-knowledge proofs
Definitions
- the present inventions relate to authentication and, more particularly, relate to authentication performed iteratively.
- Authentication is typically performed by means of a signature. Even in interactive protocols a random nonce is signed as part of the authentication step.
- Current authentication mechanisms between devices are almost exclusively based on RSA (Rivest, Shamir, Adleman), DSA (Digital Signature Algorithm), or ECC (Elliptic Curve Cryptography). Specifications for all of these can be found in Bruce Schneier's book Applied Cryptography: Protocols, Algorithms, and Source Code in C.
- OpenSSH SSH meaning Secure SHell
- No security is self-explanatory.
- Minimal security is password authentication.
- Medium is public-key based (like RSA or ECC).
- High security uses Kerberos, a public-key combined with password scheme, but there is no way of switching between them, short of completely renegotiating the entire protocol.
- a first problem inherent in existing schemes is that levels of authentication (and therefore trust) are fixed and non-interactive.
- the concept of different levels of authentication is known, but in existing systems, the only way to pass from one level of authentication to a higher level is to completely redo the entire authentication scheme from scratch, discarding any partial trust from an earlier authentication effort. This is wasteful of processing resources and suboptimal.
- a second problem is that authentication, as it currently exists, is an all-or-nothing proposition, especially between devices. For many applications, it is important to get some level of trust quickly, but high trust can wait longer, as slow processors work to prove their authenticity over days or even weeks. This is applicable to different kinds of low-power devices.
- RF neurons such as the neuRFonTM brand RF neurons under development by Motorola, Inc. of Schaumburg, Ill., USA.
- a third problem is that current schemes for device authentication are essentially fixed at a certain level of authentication, that is, the level of trust. For many applications, however, the trust required of different devices is different—in an automobile, for example, it is much more important that the master cylinder be genuine than that the turn signal is genuine.
- An object of the present inventions is to provide a method of scalable authentication having iterative characteristics
- Another object of the present inventions is to provide an authentication technique allowing a second authentication with a higher confidence level by building on a previous result of authentication without starting over at zero;
- Another further object of the present inventions is to provide an authentication technique having a selectable confidence level
- Another further again object of the present inventions is to provide an authentication technique wherein a verifier queries a prover intermittently over time;
- An additional other object of the present inventions is to provide authentication with efficient computation per iteration
- a further object of the present inventions is to provide a method for zero-knowledge authentication of a prover by a verifier
- Another object of the present inventions is to provide the novel authentication technique herein called ZEro Knowledge Exploration (ZEKE);
- a further other object of the present inventions is to provide an authentication technique using same size, square matrices
- An other further object of the present inventions is to provide an authentication technique using matrices having single digit entries
- An additional other further object of the present inventions is to provide an authentication technique using multivariate quadratic equations
- An additional object of the present inventions is to create a mechanism by which low-powered devices can authenticate themselves to another device by proving that they have access to certain private information;
- An additional further object of the present inventions is to provide authentication among devices in an ad-hoc network.
- An additional further object of the present inventions is to provide authentication among components in an automobile.
- Authentication is performed to a user-selectable confidence level.
- a prover is iteratively authenticated by a verifier. The iterations are continued until a count of the iterations reaches a number sufficient to achieve a confidence level desired by the verifier. Thus a user can select a confidence level sufficient to satisfy the security requirements of the user's environment. After a delay from completion of the authentication to achieve the desired confidence level, more iterations can continue to achieve a higher confidence level by beginning a new authentication that builds on the result of the previous authentication. During the delay, the verifier can perform tasks in reliance on the result of the earlier authentication. This allows the verifier to query the prover intermittently over time, such as in an ad hoc network or among automobile components. Since each iteration reduces doubt in the result by essentially half, it is possible to accept an early result and take advantage of more confidence checking later.
- Digital logic such as a processor and memory, a state machine, or an ASIC performs the authentication.
- the authentication of the prover by the verifier uses same size, square matrices filled with binary digit entries.
- a private key matrix K, a base matrix N are used and a masked matrix M is calculated for the prover based on the private key matrix K and the base matrix N.
- the public matrix N and the masked matrix M are understood to be public and available to anyone who asks for them, either from a repository or from the prover.
- a verifier makes an iteration request of the prover.
- the prover picks a same-size, square matrix S for a given iteration and calculates a same-size, commitment matrix C after the picking of the square matrix S.
- the square matrix S is a matrix filled with random binary bits.
- a two-state request bit is sent from the verifier to the prover after receipt of the commitment matrix C.
- the request bit is unpredictable from the perspective of the prover.
- the two-state request bit is simply a bit chosen in a random or a pseudorandom fashion.
- the prover sends the square matrix S to the verifier, and the verifier uses received matrix S and the masked matrix M to verify the commitment matrix C, if not verifiable, then authentication fails, otherwise another iteration is considered.
- the prover calculates a same-size, masked key matrix V from the square matrix S and the private key matrix K and sends the masked key matrix V to the verifier, and the verifier uses received masked key matrix V and the base matrix N to verify the commitment matrix C, if not verifiable, then authentication fails, otherwise another iteration is considered.
- FIG. 1 illustrates a schematic block diagram of a prover and a verifier of the present inventions
- FIG. 2 illustrates a flow diagram of exemplary iteration messages according to the present inventions
- FIG. 3 illustrates a flow chart of a user-selected confidence level authentication according to the present inventions
- FIG. 4 illustrates a flow chart of a zero-knowledge iteration according to the present inventions.
- FIG. 5 illustrates an exemplary application of prover and verifier components in an automobile according to the present inventions.
- FIG. 1 illustrates a schematic block diagram of a prover 110 communicating with a verifier 120 to perform authentication in an iterative fashion.
- the authentication of the prover 110 by the verifier 120 uses same size, square matrices filled with binary digit entries.
- the prover Prior to an iteration, the prover is provisioned with certain matrices which are assigned to the prover 110 for all iterations.
- a private key matrix K is established for the prover 110 .
- the private key matrix K is kept private to the prover 110 and not revealed to the public or to the verifier 120 .
- the private key matrix K can be created and installed in secure memory during manufacture, say at a factory. Alternate embodiments allow the generation of the private key matrix K at other times during a provisioning state.
- a base matrix N is picked and a masked matrix M is calculated for the prover 110 based on the private key matrix K and the base matrix N.
- the base matrix N is picked and the masked matrix M is calculated by the prover 110 during provisioning.
- a certificate containing the base matrix N and the masked matrix M is created and signed by the device manufacturer in the factory.
- the base matrix N and the masked matrix M are created after the prover 110 has left the factory and are simply stored in memory until needed.
- the base matrix N and masked matrix M 130 can be sent to the verifier 120 prior to an initial iteration, either on their own or as part of a certificate. Alternatively, the base matrix N and masked matrix M 130 can be sent after a first iteration request. Then again, the verifier 120 could be provisioned with the base matrix N and the masked matrix M before directly contacting the prover 110 .
- the verifier 120 verifies the identity of the prover 110 by making authentication and two-state requests 140 .
- the prover 110 transmits same-size square matrices commitment matrix C, square matrix S and masked key matrix V 150 to the verifier 120 .
- Both the prover 110 and the verifier 120 perform some very simple matrix multiplication operations and equality checking. This authenticates the prover's knowledge of the private key matrix K, and, therefore, its identity.
- the prover 110 and the verifier 120 are preferably devices having digital logic such as a processor and memory, a state machine or an application specific integrated circuit (ASIC). These devises can be arranged in an ad-hoc network or form network nodes such as RF neurons. Some example applications are components in an automobile or sensors in a building.
- digital logic such as a processor and memory, a state machine or an application specific integrated circuit (ASIC).
- ASIC application specific integrated circuit
- FIG. 2 illustrates a flow diagram of exemplary messages for an iteration.
- a private key matrix K is established for the prover 210 .
- the private key matrix K is kept private to the prover 210 and not revealed to the pubic or the verifier 220 .
- a base matrix N is picked.
- the base matrix N is preferably picked using the same way that the private key matrix K is picked, except that the base matrix N is made public and the private key matrix K is kept private.
- a masked matrix M is calculated for the prover based on the private key matrix K and the base matrix N.
- An authentication preferably begins with an iteration request 203 from the verifier 220 to the prover 210 .
- the iteration request 203 is a signal from the verifier 220 to the prover 210 that authentication is required.
- the iteration request 203 can be sent in any format such as a specified byte request from the verifier 220 to the prover 210 during operation or simply providing power to the prover 210 in system application such as an automobile or an RFID system.
- the prover 210 does not wait for an iteration request 203 to create the square matrix S and the commitment matrix C 205 .
- iteration requests 203 are optional if the provers 210 know to generate 205 and send out new commitment matrices C 207 —such as intermittently or whenever a device is receiving power.
- the square matrix S and the commitment matrix C are created 205 prior to receipt of the iteration request 203 and stay in memory of the prover 210 until an iteration request 203 is received.
- the stored the commitment matrix C is sent 207 to the verifier 220 .
- the values of the entries in the square matrix S are chosen randomly.
- the prover 210 creates a square matrix S.
- the verifier 220 chooses a request bit at 230 and sends the request bit to the prover 210 at 234 .
- the request bid indicates to the prover whether to return the square matrix S or to return the masked key matrix V.
- the request bit is chosen randomly (or psuedorandomly) upon receipt of the commitment matrix C.
- the sequence of request bits could be pre-generated and stored for retrieval by the verifier 220 when necessary. Other embodiments are easily envisioned to one skilled in the art.
- FIG. 3 illustrates a flow chart of a user-selected confidence level and iteration level.
- a user such as that of a verifier, determines a needed confidence level (CL) at step 310 . Determination of a confidence level allows the user to select the level of security or confidence needed. Prior authentication techniques were unable to select desired confidence level by the user or verifier that varied from authentication to authentication. Also, according to the present inventions, subsequent increases in confidence can be achieved by building on the result of all previous authentications without starting over as was required by prior authentication techniques. This is possible in part because the way the zero knowledge authentication is deployed by the present inventions.
- step 310 it is also determined in the verifier what the current iteration level (IL) is. If it is starting from the beginning, the current iteration level (IL) would be zero. If it is building upon the result of the previous authentication, say after a delay to perform some intermediate task using the previous authentication result, then the iteration level (IL) would be a larger number than zero.
- the present inventions allow for more efficient computation by building upon a prior result.
- a user can determine, at what confidence level point to quit and later have an opportunity to resume again with no loss in security efficiency. Because each iteration reduces doubt in the result by essentially half, it is possible for a user or verifier to rely on and use an early result and take advantage of more confidence checking later.
- a dishonest prover in cryptography is a prover without access to the private key, in this case the private key matrix K.
- the current iteration level (IL) is then compared against the needed confidence level (CL) at step 320 . If the current iteration level (IL) is not less than the needed confidence level (CL), then the authentication is complete at step 330 . If the current iteration level (IL) is less than the needed confidence level (CL), then an iteration is performed at step 340 . Details of an iteration will later be described below in detail with respect to the flowchart of FIG. 4 .
- step 340 After the iteration of step 340 , it is determined whether the iteration passed at step 350 . If the iteration does not pass, then authentication fails at step 370 . If the iteration passed, the count value of the iteration level (IL) is incremented at step 360 and flow continues to step 320 where it is again determined whether the current iteration level (IL) is less than the needed confidence level (CL). Depending on the result, authentication continues in iterative fashion.
- IL iteration level
- FIG. 4 illustrates a flow chart of a zero-knowledge iteration.
- the iteration steps illustrated in FIG. 4 correspond to the iteration step 340 of FIG. 3 and to the iteration pass question 350 of FIG. 3 .
- An iteration begins at step 400 .
- the verifier sends an iteration request to the prover.
- the prover then creates the square matrix S, calculates the commitment matrix C and sends the commitment matrix C to the verifier at 422 .
- the verifier picks a random request bit and sends the bit to the prover at step 424 .
- the prover receives the random request bit and determines if the bit is a first state or a second state. If a first state is received, represented arbitrarily as one, then the prover continues to step 440 . If a second state is received, represented arbitrarily as a zero, then the prover continues to step 450 .
- a selectable confidence level is achieved when iteratively authenticating a prover by a verifier. Iterations are continued until a count of the iterations reaches a number sufficient to achieve a confidence level desired by the verifier.
- the confidence level desired by the verifier can be selected in different ways. For example, the confidence level can be selected by a user of a device performing the verification. The confidence level can be predetermined, or predetermined for particular environments, times of day or events.
- the confidence level for each component prover is determined by the rigorous requirements placed on a particular component.
- the confidence level may be determined by an amount of risk taken.
- An advantage of the selectable confidence level of the authentication of the present inventions is the computational efficiency.
- the result of authentication can be used to perform a task during a delay such as some time passage. After using the result of authentication, if the verifier needs a higher confidence level, authentication can resume using the previous result without having to start all over from a zero trust level. This allows one to start an automobile or begin doing business without waiting for complete authentications while still providing for efficient higher authentications when needed at a later time.
- the verifier and prover interact in an iterative way to allow a decision by the verifier whether or not to authenticate the prover. This is accomplished by sending certain same-size square matrices from the prover to the verifier and sending a random request bit from the verifier to the prover.
- the prover must establish a private key matrix K for the prover device.
- This private key matrix K is a square matrix of a predetermined size and is preferably set to the device permanently such as at the time of device manufacture.
- the prover chooses a base matrix N of the same size as the private key matrix K.
- the base matrix N is unique to each device.
- the base matrix N may be shared by multiple devices. In any case, the base matrix N should not vary per iteration.
- the prover makes this base matrix N available to one or more of the verifiers. Though this can be revealed in advance of authentication, the base matrix N does not need to be revealed until an iteration request is received by the prover.
- the prover calculates a masked matrix M of the same size as the base matrix N.
- the masked matrix M is calculated from the private key matrix K and the base matrix N.
- M KNK T
- the masked matrix M will be unique to each device, since the private key matrix K is unique to each device.
- the prover makes this masked matrix M available to one or more of the verifiers. Though it can be revealed in advance of authentication, the masked matrix M does not need to be revealed until an iteration request is received by the prover.
- a verifier then makes an iteration request of the prover.
- the prover picks a same-size, square matrix S for this iteration after the iteration request.
- the square matrix S can be considered a matrix filled with random bits.
- the prover then sends the commitment matrix C to the verifier.
- the verifier After the verifier receives the commitment matrix C, the verifier sends a two-state request bit to the prover.
- the prover On a first request state of the request, the prover sends the square matrix S to the verifier, and the verifier uses received square matrix S and the masked matrix M to verify the commitment matrix C.
- the authentication fails. Otherwise, the verifier determines if another iteration is needed based on the principles of the user-selected confidence level discussed above. A pass decision is then issued or another iteration request is made.
- the prover calculates a same-size, masked key matrix V based on the square matrix S and the private key matrix K for this iteration.
- the masked key matrix V received is representative of the square matrix S and a private key matrix K.
- V SK
- the prover sends the masked key matrix V to the verifier, and the verifier uses received masked key matrix V and the base matrix N to verify the commitment matrix C.
- verifier determines if another iteration is needed based on the principles of the user-selected confidence level discussed above. A pass decision is then issued or another iteration request is made.
- the private key matrix K, the base matrix N, the masked matrix M, the square matrix S, the commitment matrix C, and the masked key matrix V have entries that are preferably binary digits (elements of GF(2)) to achieve computational efficiency and thus conserve processing resources. It is also preferred that the size of these matrices is no less than about 24 ⁇ 24 in the preferred embodiment to achieve balance between computational efficiency and security.
- a scalable authentication scheme is good for a number of applications, where a single strong authentication is not needed or practical in all cases.
- Ad hoc networks are networks wherein the nodes are assumed to have no prior knowledge of each other. They may not have even been provisioned by a certification authority (or they may have). In either model, a low level of trust may be initially established, to be replaced by a higher level in certain circumstances. Merely establishing the identity of a neighbor may be cheap, for example, but trusting that node as a router for your messages might require a higher level of authentication. In models where trust doesn't come from a central authority, scalable authentication can be used to establish identity for the trust model in use, too, with trust being established over days or weeks, if the processor is very weak.
- a good case can be made for scalable authentication.
- a low-level degree of authentication can be maintained at most times, but in the case of a critical time/event, the individual security level can be raised to a much higher level quickly and efficiently.
- An example of this type of system is an alarm master controlling multiple sensors.
- the sensors can be trusted at a certain level (say 40 bits) in general but contradictory or unusual reports must be accompanied by a higher trust level.
- the scalable authentication model allows this higher trust level to be achieved without needing to start over from an individual trust level of zero, too, which distinguishes it from other tiered-authentication-level schemes.
- scalable authentication might be used within a single computer.
- the main processor cares only minimally about the authenticity of many of the peripherals, but certain applications and/or certain peripherals may require a higher level of trust.
- DRM digital rights management
- a cryptographic coprocessor might be expected to prove its authenticity, and so on.
- Scalable authentication gives rise to new models when trying to build a secure system.
- FIG. 5 illustrates an exemplary application of prover and verifier components in an automobile according to the present inventions.
- a computer such as a master controller 560 controls an entire automobile.
- the master controller 560 must trust each component to do what it is told, but some parts are more important than others—for example, the trustworthiness of an antilock braking system 540 or a brake master cylinder 530 is much more important than that of the turn signal 550 , although the master controller 560 would ideally have some assurance that all parts are legitimate and behaving as expected.
- Other examples are shocks 580 , audio systems 520 among others such as 570 .
- These components of an intra-vehicle network are very low-power and can only prove small things at a time, but the computer of the master controller 560 has to trust them all. It can scale its trust level to each device independently, all within the same framework.
- the computer of the master controller 560 knows that certain instances require different values of trust.
- a drive may begin on flat ground in good weather conditions and the shock absorbers and brakes have only a certain level of trust, limited by computation and time. As the drive progresses, the road gets wet and the computer senses this. It is now even more important to trust the brake master 530 . Only under the proposed scheme can the brake master 530 iteratively prove its authenticity. In known existing authentication schemes, it would require a complete new authentication from scratch, which is very time-consuming for low-end devices. If the road conditions deteriorates, a similar authentication improvement step can be done with the shocks 520 , without affecting any of the other systems on the automobile 510 .
- the master computer also wants to verify the authenticity of many of the other car parts—the turns signal, lights, shocks/struts, etc.
- the level of authentication needed is not as high (e.g. an untrusted turn signal is not as threatening to the safe operation of the vehicle as an untrusted brake system) and cost per part is more important.
- a low level of authentication of some parts is perfectly acceptable—it makes building fraudulent parts difficult but a single fraudulent part is not a significant safety concern for the driver of the vehicle or an economic concern for legitimate parts makers.
- the overall security level of the authentication systems in the vehicle must be high.
- a low overall security level would allow for a single break to provide for easy forgery of parts, or worse, of the important sensors that provide valuable information to the master computer.
- the sensors need reasonably high individual trust levels, however, while the peripheral devices need only a minimal individual trust level.
- Another application is with RF neurons and other very low-power devices which have a need to authenticate. Very little processor power can be dedicated to security and a scalable approach which can run in reasonable time “in the background” is required.
- a third application is within a single handheld device. As handheld devices become more and more complex, it is not at all unlikely that there will be a need for various nodes within a device to authenticate other nodes. Scalable authentication is a very natural fit for this as well.
- Authentication is a means of proving identity.
- a certificate containing public information related to private information known to be held by a single entity is certified by a trusted third party.
- a short interactive protocol is done to convince the verifier (the one requesting authentication) that the prover (the one trying to show authenticity) has the private information related to the trusted public information.
- the certificate's role is to bind the public key to a specific entity. This is typically accomplished by a signed certificate. This is well under stood prior art and we are not proposing any changes to this portion of an authentication procedure.
- the general way the prover shows possession of the private information is challenge-and-response.
- the verifier first issues a random nonce to the prover.
- the prover then signs this nonce and returns it to the verifier, who verifies the signature, and, thus, the identity of the prover.
- the overall security level of an authentication system is the amount of work required to break the system. This is the amount of work required to break the hard underlying problem upon which a cryptographic authentication system is built. In general, the overall security level must be very high, as a break of the overall security level defeats all components within the entire system. The overall security level also will often be the major factor in determining the speed of operations within an authentication protocol.
- individual trust level as the trust level that has been achieved between two entities.
- the individual trust level is bounded above by the overall security level and can never exceed it. However, the individual trust level can vary anywhere between 0 and the overall security level.
- the individual trust level is either 0 (no authentication at all has been done) or equal to the overall security level of the system (fully authenticated). The middle ground is ignored. While this is acceptable and even desirable in many applications, it is not in others.
- the ZEKE (ZEro Knowledge Exploration) system of the present inventions is designed to fit the demanding criteria of a modern business solution.
- Any scalable authentication system should have the following characteristics.
- MQ Multivariate Quadratic
- the verifier is only required to store a few items. These are listed here:
- RSA for example, needs to save a 1024-bit key securely, as well as a 1024-bit modulus (or two 512-bit primes securely, for speed), as well as typically a hash algorithm and a very expensive modular multiplier (about two orders of magnitude more RAM/ROM or gates than a simple matrix multiplier). Depending on the padding used, a PRNG might also be required.
- the signed certificate is also typically stored on the device, in the same instances ZEKE would require.
- ZEKE performs reasonably favorably against standard authentication mechanisms, even with a full 80 rounds, making the individual security parameter of ZEKE match the overall security parameter of the more common authentication mechanisms. Additionally, since ZEKE scales linearly with individual security parameter (up to the overall security level), it will perform better in the near 128-bit range than current methods, which scale with time polynomial in the required security level.
- ZEKE should perform even better, as vector multiplication is extremely fast.
- Each bit of the output matrix could be computed with as few as 47 gates-24 AND gates and 23 XOR gates to combine the output. 47 gates and 576 cycles is one possible option, but it scales very nicely (e.g. 94 gates would require 288 cycles and so forth). This is a huge improvement over the gate count required for either RSA or ECC, which is especially important for very low-cost devices, or where security can only be a very small additional per-unit cost.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Mobile Radio Communication Systems (AREA)
- Storage Device Security (AREA)
- Collating Specific Patterns (AREA)
Abstract
Description
M=KNKT
C=SMST
V=SK
-
- 1. Few processor cycles—ideally less than RSA or ECC even for a comparable individual trust level. This makes the security processing either fast or have a minimal impact on the speed of the rest of the operations required within the unit.
- 2. Small ROM/RAM requirements—significantly less than RSA or ECC in either software or hardware. This is directly related to the cost of implementing the security system.
- 3. Secure—the overall security parameter must be high enough to withstand attack in the foreseeable future. Work to break of 2128 or higher is a good initial benchmark.
- 4. Easy to implement—an average programmer should be able to produce a fully working version of the entire system in a reasonable period of time. This requirement is softer than some of the others, in that a really complicated but excellent system could be purchased, but personalized implementations will often be a design goal of many corporations.
yields a 24×24 matrix with entries defined in terms of the Ni and Ki. We will call this matrix intermediate matrix Q. As an example, the first term (Q0) is the double sum
We then set Q=M, which yields 576 equations in the Qi and Mi. Since the Ni and Mi are known, this provides a system with 576 unknowns (the Ki), where the equations are generally quadratic. Not all equations are truly quadratic, as many linear terms are intermixed into the degree two terms on the diagonals.
-
- 1. K stored securely (576 bits)
- 2. N stored (576 bits)
- 3. Strong pseudorandom number generator (PRNG)
- 4. Matrix multiplier
- 5. (Opt.) M stored (576 bits)—can be re-generated
- 6. (Opt.) Certificate with N, M on it, signed by a CA
Claims (28)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/066,639 US7363492B2 (en) | 2005-02-25 | 2005-02-25 | Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices |
PCT/US2006/002014 WO2006093583A2 (en) | 2005-02-25 | 2006-01-18 | Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US11/066,639 US7363492B2 (en) | 2005-02-25 | 2005-02-25 | Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/GB2005/003570 A-371-Of-International WO2007031697A1 (en) | 2005-09-16 | 2005-09-16 | Method and apparatus for classifying video data |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/267,364 Continuation US9860482B2 (en) | 2005-09-16 | 2016-09-16 | Method and apparatus for classifying video data |
Publications (2)
Publication Number | Publication Date |
---|---|
US20060195692A1 US20060195692A1 (en) | 2006-08-31 |
US7363492B2 true US7363492B2 (en) | 2008-04-22 |
Family
ID=36933144
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/066,639 Expired - Fee Related US7363492B2 (en) | 2005-02-25 | 2005-02-25 | Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices |
Country Status (2)
Country | Link |
---|---|
US (1) | US7363492B2 (en) |
WO (1) | WO2006093583A2 (en) |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070067643A1 (en) * | 2005-09-21 | 2007-03-22 | Widevine Technologies, Inc. | System and method for software tamper detection |
US20080271115A1 (en) * | 2005-12-14 | 2008-10-30 | Koninklijke Philips Electronics, N.V. | Method and System for Authentication of a Low-Resource Prover |
US20090165128A1 (en) * | 2007-12-12 | 2009-06-25 | Mcnally Michael David | Authentication of a Contributor of Online Content |
US20100161664A1 (en) * | 2008-12-22 | 2010-06-24 | General Instrument Corporation | Method and System of Authenticating the Identity of a User of a Public Computer Terminal |
US7899753B1 (en) | 2002-03-25 | 2011-03-01 | Jpmorgan Chase Bank, N.A | Systems and methods for time variable financial authentication |
US7913082B2 (en) | 2004-09-07 | 2011-03-22 | Samsung Electronics Co., Ltd. | Authenticating address ownership using care-of address (COA) binding protocol |
US8352354B2 (en) | 2010-02-23 | 2013-01-08 | Jpmorgan Chase Bank, N.A. | System and method for optimizing order execution |
US8370389B1 (en) * | 2010-03-31 | 2013-02-05 | Emc Corporation | Techniques for authenticating users of massive multiplayer online role playing games using adaptive authentication |
US20150222669A1 (en) * | 2013-05-14 | 2015-08-06 | Dell Products, L.P. | Sensor aware security policies with embedded controller hardened enforcement |
US20160119141A1 (en) * | 2013-05-14 | 2016-04-28 | Peking University Foundr Group Co., Ltd. | Secure communication authentication method and system in distributed environment |
US11240001B2 (en) * | 2018-11-06 | 2022-02-01 | International Business Machines Corporation | Selective access to asset transfer data |
US20220327194A1 (en) * | 2021-04-08 | 2022-10-13 | Proton World International N.V. | Authentication method and device |
Families Citing this family (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080215346A1 (en) * | 2007-03-02 | 2008-09-04 | Neteller Plc | Systems and methods for identity verification |
US9832069B1 (en) | 2008-05-30 | 2017-11-28 | F5 Networks, Inc. | Persistence based on server response in an IP multimedia subsystem (IMS) |
WO2011009051A1 (en) * | 2009-07-16 | 2011-01-20 | Assa Abloy Ab | Blind verification of computer firmware |
US8788842B2 (en) * | 2010-04-07 | 2014-07-22 | Apple Inc. | System and method for content protection based on a combination of a user PIN and a device specific identifier |
US8510552B2 (en) | 2010-04-07 | 2013-08-13 | Apple Inc. | System and method for file-level data protection |
JP2014081787A (en) * | 2012-10-16 | 2014-05-08 | Sony Corp | Information processing device, information processing terminal, access authentication method, and program |
US11277412B2 (en) | 2018-05-28 | 2022-03-15 | Royal Bank Of Canada | System and method for storing and distributing consumer information |
CN104137469A (en) * | 2012-12-05 | 2014-11-05 | 索尼公司 | Information processor, verification processor, information processing method, verification processing meth od, and program |
CN104363097B (en) * | 2014-11-14 | 2017-07-11 | 电子科技大学 | The RFID inter-authentication methods of lightweight on elliptic curve |
US10235516B2 (en) * | 2016-05-10 | 2019-03-19 | Cisco Technology, Inc. | Method for authenticating a networked endpoint using a physical (power) challenge |
US11356262B2 (en) | 2018-07-03 | 2022-06-07 | Royal Bank Of Canada | System and method for anonymous location verification |
CA3048425A1 (en) | 2018-07-03 | 2020-01-03 | Royal Bank Of Canada | System and method for an electronic identity brokerage |
Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5581615A (en) | 1993-12-30 | 1996-12-03 | Stern; Jacques | Scheme for authentication of at least one prover by a verifier |
US6301664B1 (en) * | 1997-11-18 | 2001-10-09 | Telcordia Technologies, Inc. | Method and system for non-malleable and non-interactive cryptographic commitment in a network |
US6332192B1 (en) * | 1997-05-13 | 2001-12-18 | Passlogix, Inc. | Generalized user identification and authentication system |
US6369904B1 (en) * | 1998-08-18 | 2002-04-09 | Seiko Epson Corporation | User verification by zero-knowledge interactive proof |
US6456393B1 (en) * | 1998-08-18 | 2002-09-24 | Seiko Epson Corporation | Information embedding in document copies |
EP1301006A1 (en) | 2001-10-05 | 2003-04-09 | Microsoft Corporation | Granular authorization for network user sessions |
US6651167B1 (en) | 1997-10-17 | 2003-11-18 | Fuji Xerox, Co., Ltd. | Authentication method and system employing secret functions in finite Abelian group |
US20050220298A1 (en) * | 2001-12-21 | 2005-10-06 | France Telecom | Cryptographic method for distributing load among several entities and devices therefor |
US20050283198A1 (en) * | 2004-06-18 | 2005-12-22 | Haubrich Gregory J | Conditional requirements for remote medical device programming |
US7010682B2 (en) * | 2002-06-28 | 2006-03-07 | Motorola, Inc. | Method and system for vehicle authentication of a component |
US7035404B2 (en) * | 2000-03-03 | 2006-04-25 | Nec Corporation | Method and apparatus for shuffle with proof, method and apparatus for shuffle verification, method and apparatus for generating input message sequence and program for same |
US7047408B1 (en) * | 2000-03-17 | 2006-05-16 | Lucent Technologies Inc. | Secure mutual network authentication and key exchange protocol |
US7073068B2 (en) * | 2002-05-24 | 2006-07-04 | Lucent Technologies Inc. | Method and apparatus for distributing shares of a password for use in multi-server password authentication |
-
2005
- 2005-02-25 US US11/066,639 patent/US7363492B2/en not_active Expired - Fee Related
-
2006
- 2006-01-18 WO PCT/US2006/002014 patent/WO2006093583A2/en active Application Filing
Patent Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5581615A (en) | 1993-12-30 | 1996-12-03 | Stern; Jacques | Scheme for authentication of at least one prover by a verifier |
US6332192B1 (en) * | 1997-05-13 | 2001-12-18 | Passlogix, Inc. | Generalized user identification and authentication system |
US6651167B1 (en) | 1997-10-17 | 2003-11-18 | Fuji Xerox, Co., Ltd. | Authentication method and system employing secret functions in finite Abelian group |
US6301664B1 (en) * | 1997-11-18 | 2001-10-09 | Telcordia Technologies, Inc. | Method and system for non-malleable and non-interactive cryptographic commitment in a network |
US6369904B1 (en) * | 1998-08-18 | 2002-04-09 | Seiko Epson Corporation | User verification by zero-knowledge interactive proof |
US6456393B1 (en) * | 1998-08-18 | 2002-09-24 | Seiko Epson Corporation | Information embedding in document copies |
US7035404B2 (en) * | 2000-03-03 | 2006-04-25 | Nec Corporation | Method and apparatus for shuffle with proof, method and apparatus for shuffle verification, method and apparatus for generating input message sequence and program for same |
US7047408B1 (en) * | 2000-03-17 | 2006-05-16 | Lucent Technologies Inc. | Secure mutual network authentication and key exchange protocol |
EP1301006A1 (en) | 2001-10-05 | 2003-04-09 | Microsoft Corporation | Granular authorization for network user sessions |
US20050220298A1 (en) * | 2001-12-21 | 2005-10-06 | France Telecom | Cryptographic method for distributing load among several entities and devices therefor |
US7073068B2 (en) * | 2002-05-24 | 2006-07-04 | Lucent Technologies Inc. | Method and apparatus for distributing shares of a password for use in multi-server password authentication |
US7010682B2 (en) * | 2002-06-28 | 2006-03-07 | Motorola, Inc. | Method and system for vehicle authentication of a component |
US20050283198A1 (en) * | 2004-06-18 | 2005-12-22 | Haubrich Gregory J | Conditional requirements for remote medical device programming |
Non-Patent Citations (3)
Title |
---|
Goldwasser et al., "The Knowledge Complexity of Interactive Proof-Systems", ACM, 0-89791-151-2/85/005/0291, pp. 291-304, 1985. * |
J.-J Quisquater and L. Guillou, "How to Explain Zero-Knowledge Protocols to Your Children" Advances in Cryptology-CRYPTO 1989, Lecture Notes in Computer Science 435, Springer-Verlag (1990) pp. 628-631. |
Oded Goldreich, "Zero-Knowledge Twenty Years After Its Invention", http://www.wisdom.weizmann.ac.il/~oded/zk-tut02.html, pp. 1-32, Oct. 27, 2002. * |
Cited By (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9240089B2 (en) | 2002-03-25 | 2016-01-19 | Jpmorgan Chase Bank, N.A. | Systems and methods for time variable financial authentication |
US7899753B1 (en) | 2002-03-25 | 2011-03-01 | Jpmorgan Chase Bank, N.A | Systems and methods for time variable financial authentication |
US7913082B2 (en) | 2004-09-07 | 2011-03-22 | Samsung Electronics Co., Ltd. | Authenticating address ownership using care-of address (COA) binding protocol |
US20070067643A1 (en) * | 2005-09-21 | 2007-03-22 | Widevine Technologies, Inc. | System and method for software tamper detection |
US20080271115A1 (en) * | 2005-12-14 | 2008-10-30 | Koninklijke Philips Electronics, N.V. | Method and System for Authentication of a Low-Resource Prover |
US8412937B2 (en) * | 2005-12-14 | 2013-04-02 | Koninklijke Philips Electronics N.V. | Method and system for authentication of a low-resource prover |
US8291492B2 (en) * | 2007-12-12 | 2012-10-16 | Google Inc. | Authentication of a contributor of online content |
US20090165128A1 (en) * | 2007-12-12 | 2009-06-25 | Mcnally Michael David | Authentication of a Contributor of Online Content |
US8645396B2 (en) | 2007-12-12 | 2014-02-04 | Google Inc. | Reputation scoring of an author |
US9760547B1 (en) | 2007-12-12 | 2017-09-12 | Google Inc. | Monetization of online content |
US20100161664A1 (en) * | 2008-12-22 | 2010-06-24 | General Instrument Corporation | Method and System of Authenticating the Identity of a User of a Public Computer Terminal |
US9071440B2 (en) | 2008-12-22 | 2015-06-30 | Google Technology Holdings LLC | Method and system of authenticating the identity of a user of a public computer terminal |
US8352354B2 (en) | 2010-02-23 | 2013-01-08 | Jpmorgan Chase Bank, N.A. | System and method for optimizing order execution |
US8370389B1 (en) * | 2010-03-31 | 2013-02-05 | Emc Corporation | Techniques for authenticating users of massive multiplayer online role playing games using adaptive authentication |
US20160119141A1 (en) * | 2013-05-14 | 2016-04-28 | Peking University Foundr Group Co., Ltd. | Secure communication authentication method and system in distributed environment |
US9369495B2 (en) * | 2013-05-14 | 2016-06-14 | Dell Products, L.P. | Sensor aware security policies with embedded controller hardened enforcement |
US20150222669A1 (en) * | 2013-05-14 | 2015-08-06 | Dell Products, L.P. | Sensor aware security policies with embedded controller hardened enforcement |
US11240001B2 (en) * | 2018-11-06 | 2022-02-01 | International Business Machines Corporation | Selective access to asset transfer data |
US20220327194A1 (en) * | 2021-04-08 | 2022-10-13 | Proton World International N.V. | Authentication method and device |
Also Published As
Publication number | Publication date |
---|---|
WO2006093583A2 (en) | 2006-09-08 |
US20060195692A1 (en) | 2006-08-31 |
WO2006093583A3 (en) | 2006-10-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7363492B2 (en) | Method for zero-knowledge authentication of a prover by a verifier providing a user-selectable confidence level and associated application devices | |
CN114521319B (en) | Lattice-based signature with uniform secret | |
US9768962B2 (en) | Minimal disclosure credential verification and revocation | |
JP4635009B2 (en) | Use of proven secret values in communications | |
JP4572234B2 (en) | Apparatus and method for providing direct certification signature denial | |
US7664259B2 (en) | Encryption and verification using partial public key | |
Nicolosi et al. | Proactive Two-Party Signatures for User Authentication. | |
US9882890B2 (en) | Reissue of cryptographic credentials | |
US20120159155A1 (en) | Direct Anonymous Attestation Scheme with Outsourcing Capability | |
US20140089670A1 (en) | Unique code in message for signature generation in asymmetric cryptographic device | |
EP2351287B1 (en) | Method of generating a cryptographic key, network and computer program therefor | |
GB2399906A (en) | Delegating authority | |
Chow et al. | Server-aided signatures verification secure against collusion attack | |
CN110945831B (en) | Generation of anti-Sybil attack identities | |
Dharminder et al. | LCPPA: Lattice‐based conditional privacy preserving authentication in vehicular communication | |
Yavuz | Eta: efficient and tiny and authentication for heterogeneous wireless systems | |
WO2021150238A1 (en) | Remote attestation | |
KR101253683B1 (en) | Digital Signing System and Method Using Chained Hash | |
El Kassem et al. | More efficient, provably-secure direct anonymous attestation from lattices | |
Tsai | An improved cross-layer privacy-preserving authentication in WAVE-enabled VANETs | |
US20150281256A1 (en) | Batch verification method and apparatus thereof | |
CN116033414A (en) | VANETs privacy protection method and equipment | |
KR100984562B1 (en) | Cryptographic method and devices for facilitating calculations during transactions | |
Sohail et al. | Optimizing Industrial IoT Data Security Through Blockchain-Enabled Incentive-Driven Game Theoretic Approach for Data Sharing | |
CN118264387B (en) | Consensus determining method and system for intranet environment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: MOTOROLA, INC., ILLINOIS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KUHLMAN, DOUGLAS A.;DABBISH, EZZAT A.;PUHL, LARRY C.;REEL/FRAME:016331/0935 Effective date: 20050224 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: MOTOROLA MOBILITY, INC, ILLINOIS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MOTOROLA, INC;REEL/FRAME:025673/0558 Effective date: 20100731 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: MOTOROLA MOBILITY LLC, ILLINOIS Free format text: CHANGE OF NAME;ASSIGNOR:MOTOROLA MOBILITY, INC.;REEL/FRAME:029216/0282 Effective date: 20120622 |
|
AS | Assignment |
Owner name: GOOGLE TECHNOLOGY HOLDINGS LLC, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MOTOROLA MOBILITY LLC;REEL/FRAME:034419/0001 Effective date: 20141028 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20200422 |