Cryptography prior to the modern age was effectively synonymous withencryption, converting readable information (plaintext) to unintelligiblenonsense text (ciphertext), which can only be read by reversing the process (decryption). The sender of an encrypted (coded) message shares the decryption (decoding) technique only with the intended recipients to preclude access from adversaries. The cryptography literatureoften uses the names "Alice" (or "A") for the sender, "Bob" (or "B") for the intended recipient, and "Eve" (or "E") for theeavesdropping adversary.[6] Since the development ofrotor cipher machines inWorld War I and the advent of computers inWorld War II, cryptography methods have become increasingly complex and their applications more varied.
Modern cryptography is heavily based onmathematical theory and computer science practice; cryptographicalgorithms are designed aroundcomputational hardness assumptions, making such algorithms hard to break in actual practice by any adversary. While it is theoretically possible to break into a well-designed system, it is infeasible in actual practice to do so. Such schemes, if well designed, are therefore termed "computationally secure". Theoretical advances (e.g., improvements ininteger factorization algorithms) and faster computing technology require these designs to be continually reevaluated and, if necessary, adapted.Information-theoretically secure schemes that provably cannot be broken even with unlimited computing power, such as theone-time pad, are much more difficult to use in practice than the best theoretically breakable but computationally secure schemes.
Alphabet shift ciphers are believed to have been used byJulius Caesar over 2,000 years ago.[6] This is an example withk = 3. In other words, the letters in the alphabet are shifted three in one direction to encrypt and three in the other direction to decrypt.
Until modern times, cryptography referred almost exclusively to "encryption", which is the process of converting ordinary information (calledplaintext) into an unintelligible form (calledciphertext).[13] Decryption is the reverse, in other words, moving from the unintelligible ciphertext back to plaintext. Acipher (or cypher) is a pair of algorithms that carry out the encryption and the reversing decryption. The detailed operation of a cipher is controlled both by the algorithm and, in each instance, by a "key". The key is a secret (ideally known only to the communicants), usually a string of characters (ideally short so it can be remembered by the user), which is needed to decrypt the ciphertext. In formal mathematical terms, a "cryptosystem" is the ordered list of elements of finite possible plaintexts, finite possible cyphertexts, finite possible keys, and the encryption and decryption algorithms that correspond to each key. Keys are important both formally and in actual practice, as ciphers without variable keys can be trivially broken with only the knowledge of the cipher used and are therefore useless (or even counter-productive) for most purposes. Historically, ciphers were often used directly for encryption or decryption without additional procedures such asauthentication or integrity checks.
There are two main types of cryptosystems:symmetric andasymmetric. In symmetric systems, the only ones known until the 1970s, the same secret key encrypts and decrypts a message. Data manipulation in symmetric systems is significantly faster than in asymmetric systems. Asymmetric systems use a "public key" to encrypt a message and a related "private key" to decrypt it. The advantage of asymmetric systems is that the public key can be freely published, allowing parties to establish secure communication without having a shared secret key. In practice, asymmetric systems are used to first exchange a secret key, and then secure communication proceeds via a more efficient symmetric system using that key.[14] Examples of asymmetric systems includeDiffie–Hellman key exchange, RSA (Rivest–Shamir–Adleman), ECC (Elliptic Curve Cryptography), andPost-quantum cryptography. Secure symmetric algorithms include the commonly used AES (Advanced Encryption Standard) which replaced the older DES (Data Encryption Standard).[15] Insecure symmetric algorithms include children's language tangling schemes such asPig Latin or othercant, and all historical cryptographic schemes, however seriously intended, prior to the invention of theone-time pad early in the 20th century.
Incolloquial use, the term "code" is often used to mean any method of encryption or concealment of meaning. However, in cryptography, code has a more specific meaning: the replacement of a unit of plaintext (i.e., a meaningful word or phrase) with acode word (for example, "wallaby" replaces "attack at dawn"). A cypher, in contrast, is a scheme for changing or substituting an element below such a level (a letter, a syllable, or a pair of letters, etc.) to produce a cyphertext.
Cryptanalysis is the term used for the study of methods for obtaining the meaning of encrypted information without access to the key normally required to do so; i.e., it is the study of how to "crack" encryption algorithms or their implementations.
Some use the terms "cryptography" and "cryptology" interchangeably in English,[16] while others (including US military practice generally) use "cryptography" to refer specifically to the use and practice of cryptographic techniques and "cryptology" to refer to the combined study of cryptography and cryptanalysis.[17][18] English is more flexible than several other languages in which "cryptology" (done by cryptologists) is always used in the second sense above.RFC2828 advises thatsteganography is sometimes included in cryptology.[19]
The study of characteristics of languages that have some application in cryptography or cryptology (e.g. frequency data, letter combinations, universal patterns, etc.) is called cryptolinguistics. Cryptolingusitics is especially used in military intelligence applications for deciphering foreign communications.[20][21]
Before the modern era, cryptography focused on message confidentiality (i.e., encryption)—conversion ofmessages from a comprehensible form into an incomprehensible one and back again at the other end, rendering it unreadable by interceptors oreavesdroppers without secret knowledge (namely the key needed for decryption of that message). Encryption attempted to ensuresecrecy in communication, such as those ofspies, military leaders, and diplomats. In recent decades, the field has expanded beyond confidentiality concerns to include techniques for message integrity checking, sender/receiver identity authentication,digital signatures,interactive proofs andsecure computation, among others.
The main classical cipher types aretransposition ciphers, which rearrange the order of letters in a message (e.g., 'hello world' becomes 'ehlol owrdl' in a trivially simple rearrangement scheme), andsubstitution ciphers, which systematically replace letters or groups of letters with other letters or groups of letters (e.g., 'fly at once' becomes 'gmz bu podf' by replacing each letter with the one following it in theLatin alphabet).[22] Simple versions of either have never offered much confidentiality from enterprising opponents. An early substitution cipher was theCaesar cipher, in which each letter in the plaintext was replaced by a letter three positions further down the alphabet.[23]Suetonius reports thatJulius Caesar used it with a shift of three to communicate with his generals.Atbash is an example of an early Hebrew cipher. The earliest known use of cryptography is some carved ciphertext on stone inEgypt (c. 1900 BCE), but this may have been done for the amusement of literate observers rather than as a way of concealing information.
TheGreeks of Classical times are said to have known of ciphers (e.g., thescytale transposition cipher claimed to have been used by theSpartan military).[24]Steganography (i.e., hiding even the existence of a message so as to keep it confidential) was also first developed in ancient times. An early example, fromHerodotus, was a message tattooed on a slave's shaved head and concealed under the regrown hair.[13] Other steganography methods involve 'hiding in plain sight,' such as using amusic cipher to disguise an encrypted message within a regular piece of sheet music. More modern examples of steganography include the use ofinvisible ink,microdots, anddigital watermarks to conceal information.
In India, the 2000-year-oldKama Sutra ofVātsyāyana speaks of two different kinds of ciphers called Kautiliyam and Mulavediya. In the Kautiliyam, the cipher letter substitutions are based on phonetic relations, such as vowels becoming consonants. In the Mulavediya, the cipher alphabet consists of pairing letters and using the reciprocal ones.[13]
InSassanid Persia, there were two secret scripts, according to the Muslim authorIbn al-Nadim: thešāh-dabīrīya (literally "King's script") which was used for official correspondence, and therāz-saharīya which was used to communicate secret messages with other countries.[25]
David Kahn notes inThe Codebreakers that modern cryptology originated among theArabs, the first people to systematically document cryptanalytic methods.[26]Al-Khalil (717–786) wrote theBook of Cryptographic Messages, which contains the first use ofpermutations and combinations to list all possible Arabic words with and without vowels.[27]
First page of a book byAl-Kindi which discusses encryption of messages
Ciphertexts produced by aclassical cipher (and some modern ciphers) will reveal statistical information about the plaintext, and that information can often be used to break the cipher. After the discovery offrequency analysis, nearly all such ciphers could be broken by an informed attacker.[28] Such classical ciphers still enjoy popularity today, though mostly aspuzzles (seecryptogram). TheArab mathematician andpolymath Al-Kindi wrote a book on cryptography entitledRisalah fi Istikhraj al-Mu'amma (Manuscript for the Deciphering Cryptographic Messages), which described the first known use of frequency analysis cryptanalysis techniques.[29][30]
Language letter frequencies may offer little help for some extended historical encryption techniques such ashomophonic cipher that tend to flatten the frequency distribution. For those ciphers, language letter group (or n-gram) frequencies may provide an attack.
Essentially all ciphers remained vulnerable to cryptanalysis using the frequency analysis technique until the development of thepolyalphabetic cipher, most clearly byLeon Battista Alberti around the year 1467, though there is some indication that it was already known to Al-Kindi.[30] Alberti's innovation was to use different ciphers (i.e., substitution alphabets) for various parts of a message (perhaps for each successive plaintext letter at the limit). He also invented what was probably the first automaticcipher device, a wheel that implemented a partial realization of his invention. In theVigenère cipher, apolyalphabetic cipher, encryption uses akey word, which controls letter substitution depending on which letter of the key word is used. In the mid-19th centuryCharles Babbage showed that the Vigenère cipher was vulnerable toKasiski examination, but this was first published about ten years later byFriedrich Kasiski.[31]
Although frequency analysis can be a powerful and general technique against many ciphers, encryption has still often been effective in practice, as many a would-be cryptanalyst was unaware of the technique. Breaking a message without using frequency analysis essentially required knowledge of the cipher used and perhaps of the key involved, thus making espionage, bribery, burglary, defection, etc., more attractive approaches to the cryptanalytically uninformed. It was finally explicitly recognized in the 19th century that secrecy of a cipher's algorithm is not a sensible nor practical safeguard of message security; in fact, it was further realized that any adequate cryptographic scheme (including ciphers) should remain secure even if the adversary fully understands the cipher algorithm itself. Security of the key used should alone be sufficient for a good cipher to maintain confidentiality under an attack. This fundamental principle was first explicitly stated in 1883 byAuguste Kerckhoffs and is generally calledKerckhoffs's Principle; alternatively and more bluntly, it was restated byClaude Shannon, the inventor ofinformation theory and the fundamentals of theoretical cryptography, asShannon's Maxim—'the enemy knows the system'.
Different physical devices and aids have been used to assist with ciphers. One of the earliest may have been the scytale of ancient Greece, a rod supposedly used by the Spartans as an aid for a transposition cipher. In medieval times, other aids were invented such as thecipher grille, which was also used for a kind of steganography. With the invention of polyalphabetic ciphers came more sophisticated aids such as Alberti's owncipher disk,Johannes Trithemius'tabula recta scheme, andThomas Jefferson'swheel cypher (not publicly known, and reinvented independently byBazeries around 1900). Many mechanical encryption/decryption devices were invented early in the 20th century, and several patented, among themrotor machines—famously including theEnigma machine used by the German government and military from the late 1920s and duringWorld War II.[32] The ciphers implemented by better quality examples of these machine designs brought about a substantial increase in cryptanalytic difficulty after WWI.[33]
Cryptanalysis of the new mechanical ciphering devices proved to be both difficult and laborious. In the United Kingdom, cryptanalytic efforts atBletchley Park during WWII spurred the development of more efficient means for carrying out repetitive tasks, suchas military code breaking (decryption). This culminated in the development of theColossus, the world's first fully electronic, digital,programmable computer, which assisted in the decryption of ciphers generated by the German Army'sLorenz SZ40/42 machine.
Extensive open academic research into cryptography is relatively recent, beginning in the mid-1970s. In the early 1970sIBM personnel designed the Data Encryption Standard (DES) algorithm that became the first federal government cryptography standard in the United States.[34] In 1976Whitfield Diffie andMartin Hellman published the Diffie–Hellman key exchange algorithm.[35] In 1977 theRSA algorithm was published inMartin Gardner'sScientific American column.[36] Since then, cryptography has become a widely used tool in communications,computer networks, andcomputer security generally.
Some modern cryptographic techniques can only keep their keys secret if certain mathematical problems areintractable, such as theinteger factorization or thediscrete logarithm problems, so there are deep connections withabstract mathematics. There are very few cryptosystems that are proven to be unconditionally secure. Theone-time pad is one, and was proven to be so by Claude Shannon. There are a few important algorithms that have been proven secure under certain assumptions. For example, the infeasibility of factoring extremely large integers is the basis for believing that RSA is secure, and some other systems, but even so, proof of unbreakability is unavailable since the underlying mathematical problem remains open. In practice, these are widely used, and are believed unbreakable in practice by most competent observers. There are systems similar to RSA, such as one byMichael O. Rabin that are provably secure provided factoringn = pq is impossible; it is quite unusable in practice. Thediscrete logarithm problem is the basis for believing some other cryptosystems are secure, and again, there are related, less practical systems that are provably secure relative to the solvability or insolvability discrete log problem.[37]
As well as being aware of cryptographic history,cryptographic algorithm and system designers must also sensibly consider probable future developments while working on their designs. For instance, continuous improvements in computer processing power have increased the scope ofbrute-force attacks, so when specifyingkey lengths, the required key lengths are similarly advancing.[38] The potential impact ofquantum computing are already being considered by some cryptographic system designers developing post-quantum cryptography.[when?] The announced imminence of small implementations of these machines may be making the need for preemptive caution rather more than merely speculative.[5]
Claude Shannon's two papers, his1948 paper oninformation theory, and especially his1949 paper on cryptography, laid the foundations of modern cryptography and provided a mathematical basis for future cryptography.[39][40] His 1949 paper has been noted as having provided a "solid theoretical basis for cryptography and for cryptanalysis",[41] and as having turned cryptography from an "art to a science".[42] As a result of his contributions and work, he has been described as the "founding father of modern cryptography".[43]
Prior to the early 20th century, cryptography was mainly concerned withlinguistic andlexicographic patterns. Since then cryptography has broadened in scope, and now makes extensive use of mathematical subdisciplines, including information theory,computational complexity, statistics,combinatorics,abstract algebra,number theory, andfinite mathematics.[44] Cryptography is also a branch of engineering, but an unusual one since it deals with active, intelligent, and malevolent opposition; other kinds of engineering (e.g., civil or chemical engineering) need deal only with neutral natural forces. There is also active research examining the relationship between cryptographic problems andquantum physics.
Just as the development of digital computers and electronics helped in cryptanalysis, it made possible much more complex ciphers. Furthermore, computers allowed for the encryption of any kind of data representable in any binary format, unlike classical ciphers which only encrypted written language texts; this was new and significant. Computer use has thus supplanted linguistic cryptography, both for cipher design and cryptanalysis. Many computer ciphers can be characterized by their operation onbinarybit sequences (sometimes in groups or blocks), unlike classical and mechanical schemes, which generally manipulate traditional characters (i.e., letters and digits) directly. However, computers have also assisted cryptanalysis, which has compensated to some extent for increased cipher complexity. Nonetheless, good modern ciphers have stayed ahead of cryptanalysis; it is typically the case that use of a quality cipher is very efficient (i.e., fast and requiring few resources, such as memory or CPU capability), while breaking it requires an effort many orders of magnitude larger, and vastly larger than that required for any classical cipher, making cryptanalysis so inefficient and impractical as to be effectively impossible.
Research intopost-quantum cryptography (PQC) has intensified because practical quantum computers would break widely deployed public-key systems such as RSA, Diffie–Hellman and ECC. A 2017 review inNature surveys the leading PQC families—lattice-based, code-based, multivariate-quadratic and hash-based schemes—and stresses that standardisation and deployment should proceed well before large-scale quantum machines become available.[45]
Symmetric-key cryptography, where a single key is used for both encryption and decryption
Symmetric-key cryptography refers to encryption methods in which both the sender and receiver share the same key (or, less commonly, in which their keys are different, but related in an easily computable way). This was the only kind of encryption publicly known until June 1976.[35]
One round (out of 8.5) of theIDEA cipher, used in most versions ofPGP and OpenPGP compatible software for time-efficient encryption of messages
Symmetric key ciphers are implemented as eitherblock ciphers orstream ciphers. A block cipher enciphers input in blocks of plaintext as opposed to individual characters, the input form used by a stream cipher.
TheData Encryption Standard (DES) and theAdvanced Encryption Standard (AES) are block cipher designs that have been designatedcryptography standards by the US government (though DES's designation was finally withdrawn after the AES was adopted).[46] Despite its deprecation as an official standard, DES (especially its still-approved and much more securetriple-DES variant) remains quite popular; it is used across a wide range of applications, from ATM encryption[47] toe-mail privacy[48] andsecure remote access.[49] Many other block ciphers have been designed and released, with considerable variation in quality. Many, even some designed by capable practitioners, have been thoroughly broken, such asFEAL.[5][50]
Stream ciphers, in contrast to the 'block' type, create an arbitrarily long stream of key material, which is combined with the plaintext bit-by-bit or character-by-character, somewhat like theone-time pad. In a stream cipher, the output stream is created based on a hidden internal state that changes as the cipher operates. That internal state is initially set up using the secret key material.RC4 is a widely used stream cipher.[5] Block ciphers can be used as stream ciphers by generating blocks of a keystream (in place of aPseudorandom number generator) and applying anXOR operation to each bit of the plaintext with each bit of the keystream.[51]
Message authentication codes (MACs) are much likecryptographic hash functions, except that a secret key can be used to authenticate the hash value upon receipt;[5][45] this additional complication blocks an attack scheme against baredigest algorithms, and so has been thought worth the effort. Cryptographic hash functions are a third type of cryptographic algorithm. They take a message of any length as input, and output a short, fixed-lengthhash, which can be used in (for example) a digital signature. For good hash functions, an attacker cannot find two messages that produce the same hash.MD4 is a long-used hash function that is now broken;MD5, a strengthened variant of MD4, is also widely used but broken in practice. The USNational Security Agency developed the Secure Hash Algorithm series of MD5-like hash functions: SHA-0 was a flawed algorithm that the agency withdrew;SHA-1 is widely deployed and more secure than MD5, but cryptanalysts have identified attacks against it; theSHA-2 family improves on SHA-1, but is vulnerable to clashes as of 2011; and the US standards authority thought it "prudent" from a security perspective to develop a new standard to "significantly improve the robustness ofNIST's overall hash algorithm toolkit."[52] Thus, ahash function design competition was meant to select a new U.S. national standard, to be calledSHA-3, by 2012. The competition ended on October 2, 2012, when the NIST announced thatKeccak would be the new SHA-3 hash algorithm.[53] Unlike block and stream ciphers that are invertible, cryptographic hash functions produce a hashed output that cannot be used to retrieve the original input data. Cryptographic hash functions are used to verify the authenticity of data retrieved from an untrusted source or to add a layer of security.
Public-key cryptography, where different keys are used for encryption and decryption
Symmetric-key cryptosystems use the same key for encryption and decryption of a message, although a message or group of messages can have a different key than others. A significant disadvantage of symmetric ciphers is thekey management necessary to use them securely. Each distinct pair of communicating parties must, ideally, share a different key, and perhaps for each ciphertext exchanged as well. The number of keys required increases as thesquare of the number of network members, which very quickly requires complex key management schemes to keep them all consistent and secret.
In a groundbreaking 1976 paper, Whitfield Diffie and Martin Hellman proposed the notion ofpublic-key (also, more generally, calledasymmetric key) cryptography in which two different but mathematically related keys are used—apublic key and aprivate key.[54] A public key system is so constructed that calculation of one key (the 'private key') is computationally infeasible from the other (the 'public key'), even though they are necessarily related. Instead, both keys are generated secretly, as an interrelated pair.[55] The historianDavid Kahn described public-key cryptography as "the most revolutionary new concept in the field since polyalphabetic substitution emerged in the Renaissance".[56]
In public-key cryptosystems, the public key may be freely distributed, while its paired private key must remain secret. In a public-key encryption system, thepublic key is used for encryption, while theprivate orsecret key is used for decryption. While Diffie and Hellman could not find such a system, they showed that public-key cryptography was indeed possible by presenting theDiffie–Hellman key exchange protocol, a solution that is now widely used in secure communications to allow two parties to secretly agree on ashared encryption key.[35]TheX.509 standard defines the most commonly used format forpublic key certificates.[57]
Diffie and Hellman's publication sparked widespread academic efforts in finding a practical public-key encryption system. This race was finally won in 1978 byRonald Rivest,Adi Shamir, andLen Adleman, whose solution has since become known as theRSA algorithm.[58]
A document published in 1997 by the Government Communications Headquarters (GCHQ), a British intelligence organization, revealed that cryptographers at GCHQ had anticipated several academic developments.[59] Reportedly, around 1970,James H. Ellis had conceived the principles of asymmetric key cryptography. In 1973,Clifford Cocks invented a solution that was very similar in design rationale to RSA.[59][60] In 1974,Malcolm J. Williamson is claimed to have developed the Diffie–Hellman key exchange.[61]
In this example the message is only signed and not encrypted. 1) Alice signs a message with her private key. 2) Bob can verify that Alice sent the message and that the message has not been modified.
Public-key cryptography is also used for implementingdigital signature schemes. A digital signature is reminiscent of an ordinary signature; they both have the characteristic of being easy for a user to produce, but difficult for anyone else toforge. Digital signatures can also be permanently tied to the content of the message being signed; they cannot then be 'moved' from one document to another, for any attempt will be detectable. In digital signature schemes, there are two algorithms: one forsigning, in which a secret key is used to process the message (or a hash of the message, or both), and one forverification, in which the matching public key is used with the message to check the validity of the signature. RSA andDSA are two of the most popular digital signature schemes. Digital signatures are central to the operation ofpublic key infrastructures and many network security schemes (e.g.,SSL/TLS, manyVPNs, etc.).[50]
Public-key algorithms are most often based on thecomputational complexity of "hard" problems, often fromnumber theory. For example, the hardness of RSA is related to theinteger factorization problem, while Diffie–Hellman and DSA are related to thediscrete logarithm problem. The security ofelliptic curve cryptography is based on number theoretic problems involvingelliptic curves. Because of the difficulty of the underlying problems, most public-key algorithms involve operations such asmodular multiplication and exponentiation, which are much more computationally expensive than the techniques used in most block ciphers, especially with typical key sizes. As a result, public-key cryptosystems are commonlyhybrid cryptosystems, in which a fast high-quality symmetric-key encryption algorithm is used for the message itself, while the relevant symmetric key is sent with the message, but encrypted using a public-key algorithm. Similarly, hybrid signature schemes are often used, in which a cryptographic hash function is computed, and only the resulting hash is digitally signed.[5]
Cryptographic hash functions are functions that take a variable-length input and return a fixed-length output, which can be used in, for example, a digital signature. For a hash function to be secure, it must be difficult to compute two inputs that hash to the same value (collision resistance) and to compute an input that hashes to a given output (preimage resistance).MD4 is a long-used hash function that is now broken;MD5, a strengthened variant of MD4, is also widely used but broken in practice. The USNational Security Agency developed the Secure Hash Algorithm series of MD5-like hash functions: SHA-0 was a flawed algorithm that the agency withdrew;SHA-1 is widely deployed and more secure than MD5, but cryptanalysts have identified attacks against it; theSHA-2 family improves on SHA-1, but is vulnerable to clashes as of 2011; and the US standards authority thought it "prudent" from a security perspective to develop a new standard to "significantly improve the robustness ofNIST's overall hash algorithm toolkit."[52] Thus, ahash function design competition was meant to select a new U.S. national standard, to be calledSHA-3, by 2012. The competition ended on October 2, 2012, when the NIST announced thatKeccak would be the new SHA-3 hash algorithm.[53] Unlike block and stream ciphers that are invertible, cryptographic hash functions produce a hashed output that cannot be used to retrieve the original input data. Cryptographic hash functions are used to verify the authenticity of data retrieved from an untrusted source or to add a layer of security.
The goal of cryptanalysis is to find some weakness or insecurity in a cryptographic scheme, thus permitting its subversion or evasion.
It is a common misconception that every encryption method can be broken. In connection with his WWII work atBell Labs,Claude Shannon proved that theone-time pad cipher is unbreakable, provided the key material is trulyrandom, never reused, kept secret from all possible attackers, and of equal or greater length than the message.[62] Mostciphers, apart from the one-time pad, can be broken with enough computational effort bybrute force attack, but the amount of effort needed may beexponentially dependent on the key size, as compared to the effort needed to make use of the cipher. In such cases, effective security could be achieved if it is proven that the effort required (i.e., "work factor", in Shannon's terms) is beyond the ability of any adversary. This means it must be shown that no efficient method (as opposed to the time-consuming brute force method) can be found to break the cipher. Since no such proof has been found to date, the one-time-pad remains the only theoretically unbreakable cipher. Although well-implemented one-time-pad encryption cannot be broken, traffic analysis is still possible.
There are a wide variety of cryptanalytic attacks, and they can be classified in any of several ways. A common distinction turns on what Eve (an attacker) knows and what capabilities are available. In aciphertext-only attack, Eve has access only to the ciphertext (good modern cryptosystems are usually effectively immune to ciphertext-only attacks). In aknown-plaintext attack, Eve has access to a ciphertext and its corresponding plaintext (or to many such pairs). In achosen-plaintext attack, Eve may choose a plaintext and learn its corresponding ciphertext (perhaps many times); an example isgardening, used by the British during WWII. In achosen-ciphertext attack, Eve may be able tochoose ciphertexts and learn their corresponding plaintexts.[5] Finally in aman-in-the-middle attack Eve gets in between Alice (the sender) and Bob (the recipient), accesses and modifies the traffic and then forward it to the recipient.[63] Also important, often overwhelmingly so, are mistakes (generally in the design or use of one of theprotocols involved).
Cryptanalysis of symmetric-key ciphers typically involves looking for attacks against the block ciphers or stream ciphers that are more efficient than any attack that could be against a perfect cipher. For example, a simple brute force attack against DES requires one known plaintext and 255 decryptions, trying approximately half of the possible keys, to reach a point at which chances are better than even that the key sought will have been found. But this may not be enough assurance; alinear cryptanalysis attack against DES requires 243 known plaintexts (with their corresponding ciphertexts) and approximately 243 DES operations.[64] This is a considerable improvement over brute force attacks.
Public-key algorithms are based on the computational difficulty of various problems. The most famous of these are the difficulty ofinteger factorization ofsemiprimes and the difficulty of calculatingdiscrete logarithms, both of which are not yet proven to be solvable inpolynomial time (P) using only a classicalTuring-complete computer. Much public-key cryptanalysis concerns designing algorithms inP that can solve these problems, or using other technologies, such asquantum computers. For instance, the best-known algorithms for solving theelliptic curve-based version of discrete logarithm are much more time-consuming than the best-known algorithms for factoring, at least for problems of more or less equivalent size. Thus, to achieve an equivalent strength of encryption, techniques that depend upon the difficulty of factoring large composite numbers, such as the RSA cryptosystem, require larger keys than elliptic curve techniques. For this reason, public-key cryptosystems based on elliptic curves have become popular since their invention in the mid-1990s.
While pure cryptanalysis uses weaknesses in the algorithms themselves, other attacks on cryptosystems are based on actual use of the algorithms in real devices, and are calledside-channel attacks. If a cryptanalyst has access to, for example, the amount of time the device took to encrypt a number of plaintexts or report an error in a password or PIN character, they may be able to use atiming attack to break a cipher that is otherwise resistant to analysis. An attacker might also study the pattern and length of messages to derive valuable information; this is known astraffic analysis[65] and can be quite useful to an alert adversary. Poor administration of a cryptosystem, such as permitting too short keys, will make any system vulnerable, regardless of other virtues.Social engineering and other attacks against humans (e.g., bribery,extortion,blackmail, espionage,rubber-hose cryptanalysis or torture) are usually employed due to being more cost-effective and feasible to perform in a reasonable amount of time compared to pure cryptanalysis by a high margin.
Much of the theoretical work in cryptography concernscryptographicprimitives—algorithms with basic cryptographic properties—and their relationship to other cryptographic problems. More complicated cryptographic tools are then built from these basic primitives. These primitives provide fundamental properties, which are used to develop more complex tools calledcryptosystems orcryptographic protocols, which guarantee one or more high-level security properties. Note, however, that the distinction between cryptographicprimitives and cryptosystems, is quite arbitrary; for example, the RSA algorithm is sometimes considered a cryptosystem, and sometimes a primitive. Typical examples of cryptographic primitives includepseudorandom functions,one-way functions, etc.
One or more cryptographic primitives are often used to develop a more complex algorithm, called a cryptographic system, orcryptosystem. Cryptosystems (e.g.,El-Gamal encryption) are designed to provide particular functionality (e.g., public key encryption) while guaranteeing certain security properties (e.g.,chosen-plaintext attack (CPA) security in therandom oracle model). Cryptosystems use the properties of the underlying cryptographic primitives to support the system's security properties. As the distinction between primitives and cryptosystems is somewhat arbitrary, a sophisticated cryptosystem can be derived from a combination of several more primitive cryptosystems. In many cases, the cryptosystem's structure involves back and forth communication among two or more parties in space (e.g., between the sender of a secure message and its receiver) or across time (e.g., cryptographically protectedbackup data). Such cryptosystems are sometimes calledcryptographic protocols.
Lightweight cryptography (LWC) concerns cryptographic algorithms developed for a strictly constrained environment. The growth ofInternet of Things (IoT) has spiked research into the development of lightweight algorithms that are better suited for the environment. An IoT environment requires strict constraints on power consumption, processing power, and security.[71] Algorithms such as PRESENT,AES, andSPECK are examples of the many LWC algorithms that have been developed to achieve the standard set by theNational Institute of Standards and Technology.[72]
This sectionneeds expansion. You can help byadding to it.(December 2021)
Cryptography is widely used on the internet to help protect user-data and prevent eavesdropping. To ensure secrecy during transmission, many systems use private key cryptography to protect transmitted information. With public-key systems, one can maintain secrecy without a master key or a large number of keys.[73] But, some algorithms likeBitLocker andVeraCrypt are generally not private-public key cryptography. For example, Veracrypt uses a password hash to generate the single private key. However, it can be configured to run in public-private key systems. TheC++ opensource encryption libraryOpenSSL providesfree and opensource encryption software and tools. The most commonly used encryption cipher suit isAES,[74] as it has hardware acceleration for allx86 based processors that hasAES-NI. A close contender isChaCha20-Poly1305, which is astream cipher, however it is commonly used for mobile devices as they areARM based which does not feature AES-NI instruction set extension.
Cryptography can be used to secure communications by encrypting them. Websites use encryption viaHTTPS.[75] "End-to-end" encryption, where only sender and receiver can read messages, is implemented for email inPretty Good Privacy and for secure messaging in general inWhatsApp,Signal andTelegram.[75]
Operating systems use encryption to keep passwords secret, conceal parts of the system, and ensure that software updates are truly from the system maker.[75] Instead of storing plaintext passwords, computer systems store hashes thereof; then, when a user logs in, the system passes the given password through a cryptographic hash function and compares it to the hashed value on file. In this manner, neither the system nor an attacker has at any point access to the password in plaintext.[75]
Encryption is sometimes used to encrypt one's entire drive. For example,University College London has implementedBitLocker (a program by Microsoft) to render drive data opaque without users logging in.[75]
Estimates suggest that aquantum computer could reduce the effort required to break today’s strongestRSA orelliptic-curve keys from millennia to mere seconds, rendering current protocols (such as the versions ofTLS that rely on those keys) insecure.[76]
To mitigate this “quantum threat”, researchers are developingquantum-resistant algorithms whose security rests on problems believed to remain hard for both classical and quantum computers.[77]
Cryptography has long been of interest to intelligence gathering andlaw enforcement agencies.[9] Secret communications may be criminal or eventreasonous.[citation needed] Because of its facilitation ofprivacy, and the diminution of privacy attendant on its prohibition, cryptography is also of considerable interest to civil rights supporters. Accordingly, there has been a history of controversial legal issues surrounding cryptography, especially since the advent of inexpensive computers has made widespread access to high-quality cryptography possible.
In some countries, even the domestic use of cryptography is, or has been, restricted. Until 1999,France significantly restricted the use of cryptography domestically, though it has since relaxed many of these rules. InChina andIran, a license is still required to use cryptography.[7] Many countries have tight restrictions on the use of cryptography. Among the more restrictive are laws inBelarus,Kazakhstan,Mongolia,Pakistan,Singapore,Tunisia, andVietnam.[78]
In the United States, cryptography is legal for domestic use, but there has been much conflict over legal issues related to cryptography.[9] One particularly important issue has been theexport of cryptography and cryptographic software and hardware. Probably because of the importance of cryptanalysis inWorld War II and an expectation that cryptography would continue to be important for national security, many Western governments have, at some point, strictly regulated export of cryptography. After World War II, it was illegal in the US to sell or distribute encryption technology overseas; in fact, encryption was designated as auxiliary military equipment and put on theUnited States Munitions List.[79] Until the development of the personal computer, asymmetric key algorithms (i.e., public key techniques), and the Internet, this was not especially problematic. However, as the Internet grew and computers became more widely available, high-quality encryption techniques became well known around the globe.
In the 1990s, there were several challenges to US export regulation of cryptography. After thesource code forPhilip Zimmermann'sPretty Good Privacy (PGP) encryption program found its way onto the Internet in June 1991, a complaint byRSA Security (then called RSA Data Security, Inc.) resulted in a lengthy criminal investigation of Zimmermann by the US Customs Service and theFBI, though no charges were ever filed.[80][81]Daniel J. Bernstein, then a graduate student atUC Berkeley, brought a lawsuit against the US government challenging some aspects of the restrictions based onfree speech grounds. The 1995 caseBernstein v. United States ultimately resulted in a 1999 decision that printed source code for cryptographic algorithms and systems was protected asfree speech by the United States Constitution.[82]
In 1996, thirty-nine countries signed theWassenaar Arrangement, an arms control treaty that deals with the export of arms and "dual-use" technologies such as cryptography. The treaty stipulated that the use of cryptography with short key-lengths (56-bit for symmetric encryption, 512-bit for RSA) would no longer be export-controlled.[83] Cryptography exports from the US became less strictly regulated as a consequence of a major relaxation in 2000;[84] there are no longer very many restrictions on key sizes in US-exported mass-market software. Since this relaxation in US export restrictions, and because most personal computers connected to the Internet include US-sourcedweb browsers such asFirefox orInternet Explorer, almost every Internet user worldwide has potential access to quality cryptography via their browsers (e.g., viaTransport Layer Security). TheMozilla Thunderbird andMicrosoft OutlookE-mail client programs similarly can transmit and receive emails via TLS, and can send and receive email encrypted withS/MIME. Many Internet users do not realize that their basic application software contains such extensivecryptosystems. These browsers and email programs are so ubiquitous that even governments whose intent is to regulate civilian use of cryptography generally do not find it practical to do much to control distribution or use of cryptography of this quality, so even when such laws are in force, actual enforcement is often effectively impossible.[citation needed]
Another contentious issue connected to cryptography in the United States is the influence of theNational Security Agency on cipher development and policy.[9] The NSA was involved with the design ofDES during its development atIBM and its consideration by theNational Bureau of Standards as a possible Federal Standard for cryptography.[85] DES was designed to be resistant todifferential cryptanalysis,[86] a powerful and general cryptanalytic technique known to the NSA and IBM, that became publicly known only when it was rediscovered in the late 1980s.[87] According toSteven Levy, IBM discovered differential cryptanalysis,[81] but kept the technique secret at the NSA's request. The technique became publicly known only when Biham and Shamir re-discovered and announced it some years later. The entire affair illustrates the difficulty of determining what resources and knowledge an attacker might actually have.
Another instance of the NSA's involvement was the 1993Clipper chip affair, an encryption microchip intended to be part of theCapstone cryptography-control initiative. Clipper was widely criticized by cryptographers for two reasons. The cipher algorithm (calledSkipjack) was then classified (declassified in 1998, long after the Clipper initiative lapsed). The classified cipher caused concerns that the NSA had deliberately made the cipher weak to assist its intelligence efforts. The whole initiative was also criticized based on its violation ofKerckhoffs's Principle, as the scheme included a specialescrow key held by the government for use by law enforcement (i.e.wiretapping).[81]
Cryptography is central to digital rights management (DRM), a group of techniques for technologically controlling use ofcopyrighted material, being widely implemented and deployed at the behest of some copyright holders. In 1998, U.S. PresidentBill Clinton signed theDigital Millennium Copyright Act (DMCA), which criminalized all production, dissemination, and use of certain cryptanalytic techniques and technology (now known or later discovered); specifically, those that could be used to circumvent DRM technological schemes.[88] This had a noticeable impact on the cryptography research community since an argument can be made that any cryptanalytic research violated the DMCA. Similar statutes have since been enacted in several countries and regions, including the implementation in theEU Copyright Directive. Similar restrictions are called for by treaties signed byWorld Intellectual Property Organization member-states.
TheUnited States Department of Justice andFBI have not enforced the DMCA as rigorously as had been feared by some, but the law, nonetheless, remains a controversial one.Niels Ferguson, a well-respected cryptography researcher, has publicly stated that he will not release some of his research into anIntel security design for fear of prosecution under the DMCA.[89] CryptologistBruce Schneier has argued that the DMCA encouragesvendor lock-in, while inhibiting actual measures toward cyber-security.[90] BothAlan Cox (longtimeLinux kernel developer) andEdward Felten (and some of his students at Princeton) have encountered problems related to the Act.Dmitry Sklyarov was arrested during a visit to the US from Russia, and jailed for five months pending trial for alleged violations of the DMCA arising from work he had done in Russia, where the work was legal. In 2007, the cryptographic keys responsible forBlu-ray andHD DVD content scrambling werediscovered and released onto the Internet. In both cases, theMotion Picture Association of America sent out numerous DMCA takedown notices, and there was a massive Internet backlash[10] triggered by the perceived impact of such notices onfair use andfree speech.
In the United Kingdom, theRegulation of Investigatory Powers Act gives UK police the powers to force suspects to decrypt files or hand over passwords that protect encryption keys. Failure to comply is an offense in its own right, punishable on conviction by a two-year jail sentence or up to five years in cases involving national security.[8] Successful prosecutions have occurred under the Act; the first, in 2009,[91] resulted in a term of 13 months' imprisonment.[92] Similar forced disclosure laws in Australia, Finland, France, and India compel individual suspects under investigation to hand over encryption keys or passwords during a criminal investigation.
In the United States, the federal criminal case ofUnited States v. Fricosu addressed whether a search warrant can compel a person to reveal anencryptionpassphrase or password.[93] TheElectronic Frontier Foundation (EFF) argued that this is a violation of the protection from self-incrimination given by theFifth Amendment.[94] In 2012, the court ruled that under theAll Writs Act, the defendant was required to produce an unencrypted hard drive for the court.[95]
In many jurisdictions, the legal status of forced disclosure remains unclear.
The 2016FBI–Apple encryption dispute concerns the ability of courts in the United States to compel manufacturers' assistance in unlocking cell phones whose contents are cryptographically protected.
As a potential counter-measure to forced disclosure some cryptographic software supportsplausible deniability, where the encrypted data is indistinguishable from unused random data (for example such as that of adrive which has been securely wiped).
^Rivest, Ronald L. (1990). "Cryptography". In J. Van Leeuwen (ed.).Handbook of Theoretical Computer Science. Vol. 1. Elsevier.
^Bellare, Mihir; Rogaway, Phillip (21 September 2005). "Introduction".Introduction to Modern Cryptography. p. 10.
^Sadkhan, Sattar B. (December 2013). "Key note lecture multidisciplinary in cryptology and information security".2013 International Conference on Electrical Communication, Computer, Power, and Control Engineering (ICECCPCE). pp. 1–2.doi:10.1109/ICECCPCE.2013.6998773.ISBN978-1-4799-5633-3.S2CID22378547.
^Whalen, Terence (1994). "The Code for Gold: Edgar Allan Poe and Cryptography".Representations.46 (46). University of California Press:35–57.doi:10.2307/2928778.JSTOR2928778.
^Sharbaf, M.S. (1 November 2011). "Quantum cryptography: An emerging technology in network security".2011 IEEE International Conference on Technologies for Homeland Security (HST). pp. 13–19.doi:10.1109/THS.2011.6107841.ISBN978-1-4577-1376-7.S2CID17915038.
^James D. Benson; Michael J. Cummings; William S. Greaves, eds. (January 1988).Linguistics in a Systemic Perspective. John Benjamins Publishing Company. p. 38.ISBN9789027278760.
^Broemeling, Lyle D. (1 November 2011). "An Account of Early Statistical Inference in Arab Cryptology".The American Statistician.65 (4):255–257.doi:10.1198/tas.2011.10191.S2CID123537702.
^Cryptography Exam Study Essentials - A Comprehensive Guide to Cryptography Concepts for Exams (1st ed.). Cybellium Ltd (published 26 October 2024). 2024. p. 78.ISBN9781836794936.
^Paar, Christof (2009).Understanding cryptography : a textbook for students and practitioners. Jan Pelzl. Berlin: Springer. p. 123.ISBN978-3-642-04101-3.OCLC567365751.
^Ralph Merkle was working on similar ideas at the time and encountered publication delays, and Hellman has suggested that the term used should be Diffie–Hellman–Merkle asymmetric key cryptography.
Arbib, Jonathan; Dwyer, John (2011).Discrete Mathematics for Cryptography. Algana Publishing.ISBN978-1-907934-01-8.
Becket, B (1988).Introduction to Cryptology. Blackwell Scientific Publications.ISBN978-0-632-01836-9.OCLC16832704. Excellent coverage of many classical ciphers and cryptography concepts and of the "modern" DES and RSA systems.
Esslinger, Bernhard; et al.The CrypTool Script(PDF) (10th ed.). Archived fromthe original(PDF) on 22 July 2011. Retrieved23 December 2013.CrypTool is the most widespread e-learning program about cryptography and cryptanalysis, open source.
In Code: A Mathematical Journey bySarah Flannery (with David Flannery). Popular account of Sarah's award-winning project on public-key cryptography, co-written with her father.
James Gannon,Stealing Secrets, Telling Lies: How Spies and Codebreakers Helped Shape the Twentieth Century, Washington, D.C., Brassey's, 2001,ISBN1-57488-367-4.
Tenzer, Theo (2021):Super Secreto – The Third Epoch of Cryptography: Multiple, exponential, quantum-secure and above all, simple and practical Encryption for Everyone, Norderstedt,ISBN978-3755761174.
A Course in Cryptography by Raphael Pass & Abhi Shelat – offered at Cornell in the form of lecture notes.
For more on the use of cryptographic elements in fiction, see:Dooley, John F. (23 August 2012)."Cryptology in Fiction". Archived fromthe original on 29 July 2020. Retrieved20 February 2015.