US 7209561 B1 Abstract A method for generating a seed value for use in symmetric encryption includes creating and storing a first data set and generating a hashed value based on the first data set. A replacement position in the first data set is selected, and at least a portion of the hashed value is written into the first data set at the replacement position. A seed portion of the first data set is selected as the seed value. By varying a number of iterations, a balance can be struck between performance (fewer iterations) and security (more iterations).
Claims(37) 1. A method of generating a seed value for use in symmetric encryption, the method comprising the computer-implemented steps of:
(a) creating and storing a first data set;
(b) generating a hashed value based on the first data set;
(c) selecting, based on a time-based value associated with the step of generating the hashed value, a replacement position in the first data set;
(d) writing at least a portion of the hashed value into the first data set at the replacement position;
(e) selecting, as the seed value, a seed portion of the first data set;
(f) generating a symmetric encryption key based on the seed value; and
(g) encrypting, using the symmetric encryption key, data communicated to a computer system.
2. A method as recited in
3. A method as recited in
4. A method as recited in
5. A method as recited in
6. A method as recited in
7. A method as recited in
8. A method of generating a seed value for use in symmetric encryption, the method comprising the computer-implemented steps of:
(a) creating and storing a first data set;
(b) generating a first index value;
(c) generating a hashed value based on the first data set;
(d) generating a second index value;
(e) selecting a hash portion from the hashed value, wherein the hash portion has a size equal to the second index value;
(f) writing the hash portion into the first data set at a replacement position specified by the first index value;
(g) generating a seed index value;
(h) selecting, as the seed value, a portion of the first data set at a seed position specified by the seed index value;
(i) generating a symmetric encryption key based on the seed value; and
(j) encrypting, using the symmetric encryption key, data communicated to a computer system.
9. A method as recited in
10. A method as recited in
11. A method as recited in
12. A method as recited in
13. A method as recited in
14. A computer-readable medium carrying one or more sequences of instructions for generating a seed value for use in symmetric encryption, which instructions, when executed by one or more processors, cause the one or more processors to carry out the steps of:
(a) creating and storing a first data set;
(b) generating a hashed value based on the first data set;
(c) selecting, based on a time-based value associated with the step of generating the hashed value, a replacement position in the first data set;
(d) writing at least a portion of the hashed value into the first data set at the replacement position;
(e) selecting, as the seed value, a seed portion of the first data set;
(f) generating a symmetric encryption key based on the seed value; and
(g) encrypting, using the symmetric encryption key, data communicated to a computer system.
15. A computer-readable medium as recited in
16. A computer-readable medium as recited in
17. A computer-readable medium as recited in
18. A computer-readable medium as recited in
19. A computer-readable medium as recited in
20. A computer-readable medium as recited in
21. An apparatus for generating a seed value for use in symmetric encryption, the apparatus comprising:
means for creating and storing a first data set;
means for generating a hashed value based on the first data set;
means for selecting, based on a time-based value associated with the step of generating the hashed value, a replacement position in the first data set;
means for writing at least a portion of the hashed value into the first data set at the replacement position;
means for selecting, as the seed value, a seed portion of the first data set;
means for generating a symmetric encryption key based on the seed value; and
means for encrypting, using the symmetric encryption key, data communicated to a computer system.
22. An apparatus as recited in
23. An apparatus as recited in
24. An apparatus as recited in
25. An apparatus as recited in
26. An apparatus as recited in
27. An apparatus as recited in
28. An apparatus for generating a seed value for use in symmetric encryption, the apparatus comprising:
a network interface that is coupled to a data network for receiving one or more packet flows therefrom;
a processor;
one or more stored sequences of instructions which, when executed by the processor, cause the processor to carry out the steps of:
creating and storing a first data set;
generating a hashed value based on the first data set;
selecting, based on a time-based value associated with the step of generating the hashed value, a replacement position in the first data set;
writing at least a portion of the hashed value into the first data set at the replacement position;
selecting, as the seed value, a seed portion of the first data set;
generating a symmetric encryption key based on the seed value; and
encrypting, using the symmetric encryption key, data communicated to a computer system.
29. An apparatus as recited in
30. An apparatus as recited in
31. An apparatus as recited in
32. An apparatus as recited in
33. An apparatus as recited in
34. An apparatus as recited in
35. A computer-readable medium carrying one or more sequences of instructions for generating a seed value for use in encryption, which instructions, when executed by one or more processors, cause the one or more processors to carry out the steps of:
(a) creating and storing a first data set;
(b) generating a first index value;
(c) generating a hashed value based on the first data set;
(d) generating a second index value;
(e) selecting a hash portion from the hashed value, wherein the hash portion has a size equal to the second index value;
(f) writing the hash portion into the first data set at a replacement position specified by the first index value;
(g) generating a seed index value;
(h) selecting, as the seed value, a portion of the first data set at a seed position specified by the seed index value;
(i) generating a symmetric encryption key based on the seed value; and
(j) encrypting, using the symmetric encryption key, data communicated to a computer system.
36. A system for generating a seed value for use in encryption, the system comprising:
(a) means for creating and storing a first data set;
(b) means for generating a first index value;
(c) means for generating a hashed value based on the first data set;
(d) means for generating a second index value;
(e) means for selecting a hash portion from the hashed value, wherein the hash portion has a size equal to the second index value;
(f) means for writing the hash portion into the first data set at a replacement position specified by the first index value;
(g) means for generating a seed index value;
(h) means for selecting, as the seed value, a portion of the first data set at a seed position specified by the seed index value;
(i) means for generating a symmetric encryption key based on the seed value; and
(j) means for encrypting, using the symmetric encryption key, data communicated to a computer system.
37. An apparatus for generating a seed value for use in symmetric encryption, the apparatus comprising:
a network interface that is coupled to a data network for receiving one or more packet flows therefrom;
a processor;
one or more stored sequences of instructions which, when executed by the processor, cause the processor to carry out the steps of:
(a) creating and storing a first data set;
(b) generating a first index value;
(c) generating a hashed value based on the first data set;
(d) generating a second index value;
(e) selecting a hash portion from the hashed value, wherein the hash portion has a size equal to the second index value;
(f) writing the hash portion into the first data set at a replacement position specified by the first index value;
(g) generating a seed index value;
(h) selecting, as the seed value, a portion of the first data set at a seed position specified by the seed index value;
(i) generating a symmetric encryption key based on the seed value; and
(j) encrypting, using the symmetric encryption key, data communicated to a computer system.
Description This application claims the benefit of prior Provisional application 60/397,474, filed Jul. 19, 2002, the entire contents of which is hereby incorporated by reference as if fully set forth herein, under 35 U.S.C. §119(e). The present invention generally relates to computer-based cryptography. The invention relates more specifically to a system and method for generating encryption seed values. The approaches described in this section could be pursued, but are not necessarily approaches that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, the approaches described in this section are not prior art to the claims in this application and are not admitted to be prior art by inclusion in this section. Computer-based cryptography techniques are widely used for encrypting and decrypting data communications. Generally, encryption approaches are classified as symmetric or asymmetric. In symmetric cryptography, the same key is used to encrypt and decrypt the data. In asymmetric approaches, different keys are used for encryption and decryption. Many symmetric cryptography approaches require a seed value as input for use in generating a unique key value for a particular data set. For example, certain block ciphers such as Data Encryption Standard (DES) use keys that are generated from random seed values. In some such approaches, theoretically perfect security is achieved when the seed value is a truly random value; this is because a truly random value is not predictable and therefore extremely difficult to guess. Further, the mechanism used to generate a truly random value is normally extremely difficult for a malicious party to reverse-engineer based only on possession of example seed values. In practice, however, generating truly random values is difficult, and therefore a variety of pseudo-random seed value generation approaches are also used. An example of a known approach for generating a random seed value involves counting the number of process threads that are instantiated by a computer operating system in a specified time. Historically, this and other techniques for generating truly random or pseudo-random seed values have been either extremely time-consuming in terms of computer processing time, or non-random. Both are undesirable. For example, in certain client-server business applications where all communications between the client and server are encrypted and decrypted, transaction processing may be perceptibly slower when a slow seed generation technique is used. Customers of these applications and the vendors who provide them would prefer an approach in which seed generation requires minimal time. Further, having a non-random seed generator affects security. Several known approaches for generating seed values have bugs or other characteristics such that the seed values are not truly random. Indeed, nearly all seed generation approaches that profess to be truly random are, in fact, pseudo-random, as described in B. Schneier, “Applied Cryptography” (John Wiley & Sons, Inc., 2 Based on the foregoing, there is a clear need for an improved approach for generating seed values for use in symmetric encryption. The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which: A method and apparatus for generating a seed value is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the present invention. Embodiments are described herein according to the following outline: -
- 1.0 General Overview
- 2.0 Structural and Functional Overview
- 3.0 Structural Elements of Generating a Seed Value
- 4.0 Method of Generating a Seed Value
- 5.0 Implementation Mechanisms—Hardware Overview
- 6.0 Extensions and Alternatives
1.0 General Overview
The needs identified in the foregoing Background, and other needs and objects that will become apparent for the following description, are achieved in the present invention, which comprises, in one aspect, a method for generating a seed value for use in symmetric encryption. The method includes creating and storing a first data set and generating a hashed value based on the first data set. A replacement position in the first data set is selected, and at least a portion of the hashed value is written into the first data set at the replacement position. A seed portion of the first data set is selected as the seed value. In another aspect of the invention, a method of generating a seed value for use in symmetric encryption includes creating and storing a first data set. A first index value is generated; a hashed value based on the first data set is generated; and, a second index value is generated. A hash portion is selected from the hashed value. The hash portion has a size equal to the second index value. The hash portion is written into the first data set at a replacement position specified by the first index value. A seed index value is also generated. A portion of the first data set at a seed position specified by the seed index value is selected as the seed value. In other aspects, the invention encompasses a computer apparatus, and a computer readable medium, including a carrier wave, configured to carry out the foregoing steps. 2.0 Structural and Functional Overview In general, according to the approach herein, a new random seed value is generated based on an array of data that changes its value continually. A value in the array of data is hashed. Time-based index values, which are inherently variable, determine what portion of the hashed data is mixed with what portion of the array of data in an iterative process. As a result, the random seed value is generated. By varying the number of iterations, a balance can be struck between performance (fewer iterations) and security (more iterations). In one embodiment, a relatively small pool of arbitrary data, such as approximately 600 bytes, is created and stored in an array in memory. A portion of the data pool, selected based on time, is mixed with hashed data at each of one or more iterations. After several iterations, all of the data pool is mixed. The mixed data provides a source for generating a random seed for use in generating a symmetric encryption key. In step In step In step A second seed may be generated by returning to step 3.0 Structural Elements of Generating a Seed Value The system also includes three fields that may be stored in memory or on disk. A hash field The system The process 4.0 Method of Generating a Seed Value Initially, in step In step In step In step In step In step In step The preceding process is repeated one or more times, as indicated by an arrow returning control to step After a specified number of iterations of the preceding process, the array In step In step Using the foregoing process, a seed value useful in generating a symmetric encryption key value is produced efficiently and rapidly. The index values used in the process can be calculated from clock or time values that are taken at irregular intervals. The data in array The number of iterations can be changed depending on the level of security that is desired. The amount of processing time required by the system to generate a seed value may be tuned by changing the number of iterations. Thus, the number of iterations may be changed to balance the security and processing time of the method. The data in array 5. Implementation Mechanisms—Hardware Overview Computer system The invention is related to the use of computer system The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to processor Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punchcards, papertape, any other physical medium with patterns of holes, a RAM, a PROM, and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave as described hereinafter, or any other medium from which a computer can read. Various forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to processor Computer system Network link Computer system The received code may be executed by processor 6.0 Extensions and Alternatives In the foregoing specification, the invention has been described with reference to specific embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |