510 likes | 553 Views
Learn how DES or AES can encipher messages using modern block ciphers efficiently, with modes of operation ensuring security and integrity, such as ECB, CBC, CFB, OFB, CTR.
E N D
Encipherment Using Modern Symmetric-Key Ciphers
Objectives ❏ To show how modern standard ciphers, such as DES or AES, can be used to encipher long messages.
8-1 USE OF MODERN BLOCK CIPHERS Symmetric-key encipherment can be done using modern block ciphers. Modes of operation have been devised to encipher text of any size employing either DES or AES.
Continued Modes of operation
Electronic Codebook (ECB) Mode The simplest mode of operation is called the electronic codebook (ECB) mode. Electronic codebook (ECB) mode
Security Issues • Pattern at block level are preserved • Block independence creates opportunities for Eve to exchange some cipher text block without knowing key.
Example Assume that Eve works in a company a few hours per month (her monthly payment is very low). She knows that the company uses several blocks of information for each employee in which the seventh block is the amount of money to be deposited in the employee’s account. Eve can intercept the ciphertext sent to the bank at the end of the month, replace the block with the information about her payment with a copy of the block with the information about the payment of a full-time colleague. Each month Eve can receive more money than she deserves.
Error Propagation A single bit error in transmission can create errors in the corresponding block. However, the error does not have any effect on the other blocks.
Cipher Block Chaining (CBC) Mode In CBC mode, each plaintext block is exclusive-ored with the previous ciphertext block before being encrypted. Cipher block chaining (CBC) mode
Continued It can be proved that each plaintext block at Alice’s site is recovered exactly at Bob’s site. Because encryption and decryption are inverses of each other, Initialization Vector (IV) The initialization vector (IV) should be known by the sender and the receiver.
Error Propagation In CBC mode, a single bit error in ciphertext block Cj during transmission may create error in most bits in plaintext block Pj during decryption.
Cipher Feedback (CFB) Mode In some situations, we need to use DES or AES as secure ciphers, but the plaintext or ciphertext block sizes are to be smaller. Encryption in cipher feedback (CFB) mode
Note In CFB mode, encipherment and decipherment use the encryption function of the underlying block cipher. The relation between plaintext and ciphertext blocks is shown below:
CFB as a Stream Cipher Cipher feedback (CFB) mode as a stream cipher
Output Feedback (OFB) Mode In this mode each bit in the ciphertext is independent of the previous bit or bits. This avoids error propagation. Encryption in output feedback (OFB) mode
OFB as a Stream Cipher Output feedback (OFB) mode as a stream cipher
Counter (CTR) Mode In the counter (CTR) mode, there is no feedback. The pseudorandomness in the key stream is achieved using a counter. Encryption in counter (CTR) mode
USE OF STREAM CIPHERS Although the five modes of operations enable the use of block ciphers for encipherment of messages or files in large units and small units, sometimes pure stream are needed for enciphering small units of data such as characters or bits. RC4A5/1
RC4 RC4 is a byte-oriented stream cipher in which a byte (8 bits) of a plaintext is exclusive-ored with a byte of key to produce a byte of a ciphertext. State RC4 is based on the concept of a state.
Initialization Initialization is done in two steps:
Key Stream Generation The keys in the key stream are generated, one by one.
A5/1 A5/1 (a member of the A5 family of ciphers) is used in the Global System for Mobile Communication (GSM), a network for mobile telephone communication.. General outline of A5/1
Key Generator A5/1 uses three LFSRs with 19, 22, and 23 bits. Three LFSR’s in A5/1
Initialization 1. set all bits in three LFSRs to 0. 2. Mix the 64 bit key with the value of register according to following code 3. Repeat above procedure but use 22 bit frame buffer
4. For 100 cycles clock the whole generator but use majority function to see which LFSR should be clocked.
A5/1 workingexample 18 17 16 1 0 1 21 20 22 0 0 1 0 R1 C1 clock control 21 20 0 1 1 1 R2 C2 0 0 R3 C3
Integrity • Prevent (or at least detect) unauthorized modification of data • Encryption provides confidentiality (prevents unauthorized disclosure) • Encryption alone does not assure integrity
MESSAGE INTEGRITY • The cryptography systems that we have studied so far provide secrecy, or confidentiality, but not integrity. However, there are occasions where we may not even need secrecy but instead must have integrity • One way to preserve the integrity of a document is through the use of a fingerprint. If Alice needs to be sure that the contents of her document will not be changed, she can put her fingerprint at the bottom of the document.
Message and Message Digest The electronic equivalent of the document and fingerprint pair is the message and digest pair. Message and digest
Difference Note The two pairs (document / fingerprint) and (message / message digest) are similar, with some differences. The document and fingerprint are physically linked together. The message and message digest can be unlinked separately, and, most importantly, the message digest needs to be safe from change. The message digest needs to be safe from change.
Checking Integrity Checking integrity
Cryptographic Hash Function Criteria A cryptographic hash function must satisfy three criteria: preimage resistance, second preimage resistance, and collision resistance. Criteria of a cryptographic hash function
Preimage Resistance Preimage
Second Preimage Resistance Second preimage
Continued Collision Resistance Collision
MESSAGE AUTHENTICATION • A message digest does not authenticate the sender of the message. To provide message authentication, Alice needs to provide proof that it is Alice sending the message and not an impostor. The digest created by a cryptographic hash function is normally called a modification detection code (MDC). What we need for message authentication is a message authentication code (MAC).
Modification Detection Code (MDC) • A modification detection code (MDC) is a message digest that can prove the integrity of the message: that message has not been changed. • If Alice needs to send a message to Bob and be sure that the message will not change during transmission, Alice can create a message digest, MDC, and send both the message and the MDC to Bob. • Bob can create a new MDC from the message and compare the received MDC and the new MDC. If they are the same, the message has not been changed.
Message Authentication Code (MAC) Message authentication code
Note The security of a MAC depends on the security of the underlying hash algorithm.
Continued Nested MAC Nested MAC
Continued HMAC Details of HMAC Ipad=(36)H Opad=(5c)H
Continued CMAC