- Symmetric-key algorithm
Symmetric-key algorithms are a class of
algorithm s forcryptography that use trivially related, often identical,cryptographic key s for both decryption and encryption.The encryption key is trivially related to the decryption key, in that they may be identical or there is a simple transform to go between the two keys. The keys, in practice, represent a
shared secret between two or more parties that can be used to maintain a private information link.Other terms for symmetric-key encryption are secret-key, single-key, shared-key, one-key and eventually private-key encryption. Use of the latter term does conflict with the term "private key" in
public-key cryptography .Types of symmetric-key algorithms
Symmetric-key algorithms can be divided into
stream cipher s andblock cipher s. Stream ciphers encrypt the bits of the message one at a time, and block ciphers take a number of bits and encrypt them as a single unit. Blocks of 64 bits have been commonly used; theAdvanced Encryption Standard algorithm approved byNIST in December2001 uses 128-bit blocks.Some examples of popular and well-respected symmetric algorithms include
Twofish , Serpent, AES (aka Rijndael), Blowfish,CAST5 ,RC4 , TDES, and IDEA.Symmetric vs. asymmetric algorithms
Unlike symmetric algorithms,
asymmetric key algorithm s use a different key for encryption than for decryption. I.e., a user knowing the encryption key of an asymmetric algorithm can encrypt messages, but cannot derive the decryption key and cannot decrypt messages encrypted with that key. A short comparison of these two types of algorithms is given below:Speed
Symmetric-key algorithms are generally much less computationally intensive than asymmetric key algorithms. In practice, asymmetric key algorithms are typically hundreds to thousands times slower than symmetric key algorithms.
Key management
:"Main article:
Key management "One disadvantage of symmetric-key algorithms is the requirement of a "shared secret key", with one copy at each end. In order to ensure secure communications between everyone in a population of n people a total of "n"("n" − 1)/2 keys are needed, which is the total number of possible communication channels. [cite book|first=Albrecht|last=Beutelspacher|year=1994|title=Cryptology|chapter=The Future Has Already Started or Public Key Cryptography|editor=|others=translation from German by J. Chris Fisher|pages=102|publisher=|id=ISBN 0-88385-504-6] To limit the impact of a potential discovery by a cryptographic adversary, they should be changed regularly and kept secure during distribution and in service. The process of selecting, distributing and storing keys is known askey management , and is difficult to achieve reliably and securely.Hybrid cryptosystem
:"Main article:
hybrid cryptosystem "In moderncryptosystem s designs, both asymmetric (public key) and symmetric algorithms are used to take advantage of the virtues of both. Asymmetric algorithms are used to distribute symmetric-keys at the start of a session. Once a symmetric key is known to all parties of the session, faster symmetric-key algorithms using that key can be used to encrypt the remainder of the session. This simplifies the key distribution problem, because asymmetric keys only have to be distributed authentically, whereas symmetric keys need to be distributed in an authentic and confidential manner.Systems that use such a hybrid approach include SSL, PGP and GPG, etc.
Cryptographic primitives based on symmetric ciphers
Symmetric ciphers are often used to achieve other cryptographic primitives than just encryption.
Encrypting a message does not guarantee that this message is not changed while encrypted. Hence often a
message authentication code is added to a ciphertext to ensure that changes to the ciphertext will be noted by the receiver. Message authentication codes can be constructed from symmetric ciphers (e.g.CBC-MAC ). However, these messages authentication codes cannot be used fornon-repudiation purposes.Another application is to build hash functions from block ciphers. See
one-way compression function for descriptions of several such methods.Construction of symmetric ciphers
:"Main article:
Feistel cipher "Many modern block ciphers are based on a construction proposed by Horst Feistel. Feistel's construction allows to build invertible functions from other functions that are itself not invertible.
Security of symmetric ciphers
Symmetric ciphers have historically been susceptible to
known-plaintext attack s,chosen plaintext attack s,differential cryptanalysis andlinear cryptanalysis . Careful construction of the functions for each round can greatly reduce the chances of a successKey generation
When used with asymmetric ciphers for key transfer, pseudorandom key generators are nearly always used to generate the symmetric cipher session keys. However, lack of randomness in those generators or in their
initialization vector s is disastrous and has led to cryptanalytic breaks in the past. Therefore, it is essential that an implementation uses a source of high entropy for its initialization.Notes
Wikimedia Foundation. 2010.
Look at other dictionaries:
Key generation — is the process of generating keys for cryptography. A key is used to encrypt and decrypt whatever data is being encrypted/decrypted.Modern cryptographic systems include symmetric key algorithms (such as DES and AES) and public key algorithms… … Wikipedia
Key size — In cryptography, key size or key length is the size measured in bits[1] of the key used in a cryptographic algorithm (such as a cipher). An algorithm s key length is distinct from its cryptographic security, which is a logarithmic measure of the… … Wikipedia
Key (cryptography) — In cryptography, a key is a piece of information (a parameter) that determines the functional output of a cryptographic algorithm or cipher. Without a key, the algorithm would produce no useful result. In encryption, a key specifies the… … Wikipedia
Key authentication — is a problem that arises when using public key cryptography. It is the process of assuring that the public key of person A held by person B does in fact belong to person A .In traditional symmetric key cryptography, this problem wasn t an issue… … Wikipedia
Key exchange — is any method in cryptography by which cryptographic keys are exchanged between users, allowing use of a cryptographic algorithm. If Alice and Bob wish to exchange encrypted messages, each must be equipped to decrypt received messages and to… … Wikipedia
Key Wrap — constructions are a class of symmetric encryption algorithms designed to encapsulate (encrypt) cryptographic key material. The Key Wrap algorithms are intended for applications such as (a) protecting keys while in untrusted storage, or (b)… … Wikipedia
Key encapsulation — mechanisms (KEMs) are a form of encryption algorithm designed to secure cryptographic key material. Key encapsulation constructions are typically asymmetric (public key) algorithms, although an equivalent symmetric notion is referred to as Key… … Wikipedia
Public-key cryptography — In an asymmetric key encryption scheme, anyone can encrypt messages using the public key, but only the holder of the paired private key can decrypt. Security depends on the secrecy of that private key … Wikipedia
Diffie–Hellman key exchange — (D–H)[nb 1] is a specific method of exchanging keys. It is one of the earliest practical examples of key exchange implemented within the field of cryptography. The Diffie–Hellman key exchange method allows two parties that have no prior knowledge … Wikipedia
International Data Encryption Algorithm — IDEA An encryption round of IDEA General Designers Xuejia Lai and James Massey … Wikipedia