Implementing the RC4 Algorithm
Simple Cryptography . The book, “Codes Ciphers and Computers” (Bosworth) describes modulo 2 addition as binary addition without the carry. It is commonly called an exclusive OR (XOR). The symbol () is used to represent an exclusive OR.
Simple Cryptography The rules for modulo 2 addition () are: 1 1 = 0 1 0 = 1 0 1 = 1 0 0 = 0
Simple Cryptography Using the ASCII character set to represent a plain text message, “Hello!” and a secret key, “Secret” in binary bit strings we can them together to produce a cipher text message.
Simple Cryptography Message: H e l l o ! 01001000 01100101 01101100 01101100 01101111 00100001 Secret Key: S e c r e t 01010011 01100101 01100011 01110010 01100101 01110100 = Cipher text: 00011011 00000000 00001111 00011110 00001010 01010101
Simple Cryptography To undo the cipher text, the cipher text with the same secret key and the original message is reproduced.
Simple Cryptography Secret Key: S e c r e t 01010011 01100101 01100011 01110010 01100101 01110100 Cipher text: 00011011 00000000 00001111 00011110 00001010 01010101 = Message: 01001000 01100101 01101100 01101100 01101111 00100001 H e l l o !
Stream Ciphers A stream cipher starts with a small secret key that is permutated into a cryptographic bit-stream. The bit-stream generator (C) is used to a plaintext message (M) into a cipher text message (P). The same algorithm is used on the other end to the cipher text message back into plaintext. M C = P Encryption P C = M Decryption
RC4 Dr. Ronald Rivest’s RC4 Stream Cipher has two components. Stream Setup. Byte Generator.
RC4 Stream Setup Two arrays: S[256] and K[256]. S0=0, S1=1, S2=2, …, S255=255. K0= 1st byte of key K1= 2nd byte of key Repeated until end of key Key repeated until K255 is filled
RC4 Stream Setup Counters A and B initialized to 0 for (A = 0; A < 256; A++) B=(B + S[A] + K[A]) mod 256 swap S[A] and S[B]
RC4 Byte Generator Counters I and J both initialized to 0 I = (I + 1) mod 256 J = (J + S[ I ] ) mod 256 swap S[ I ] and S[ J ] K = ( S[ I ] + S [ J ] ) mod 256 return S[ K ]
Initialization Vector (IV) Stream Ciphers produce the exact same cipher stream when the key is identical. To synchronize the stream an IV is used. It represents the number of permutations needed to produce a cipher byte.
RC4 Common Uses IEEE 802.11 Wired Equivalent Privacy (WEP) protocol. Walker, J. (2000). Unsafe at any key size; An analysis of the WEP encapsulation. IEEE Working Group P802.11. Document Number IEE802.11-00/362 [online] http://grouper.ieee.org /groups/802/11/Documents/DT351-400.html
Conclusion RC4 is an easily remembered algorithm RC4 is fast. RC4 can be implemented in most languages using only a few lines of code.