Professional Documents
Culture Documents
Final Public Key Cryptography
Final Public Key Cryptography
Computes: M = Cd mod n
In RSA have:
n=p.q
ø(n)=(p-1)(q-1)
Hence :
Cd = Me.d = M1+k.ø(n) = M1.(Mø(n))k
• = M1.(1)k = M1 = M mod n
RSA Example - Key Setup
1. Select primes: p=17 & q=11
2. Calculate n = pq =17 x 11=187
3. Calculate ø(n)=(p–1)(q-1)=16x10=160
4. Select e: gcd(e,160)=1; choose e=7
5. Determine d: de=1 mod 160 and d < 160
Value is d=23 since 23x7=161= 10x160+1
6. Publish public key PU={7,187}
7. Keep secret private key PR={23,187}
RSA Example - En/Decryption
Sample RSA encryption/decryption is:
Given message M = 88 (nb. 88<187)
Encryption:
C = 887 mod 187 = 11
Decryption:
M = 1123 mod 187 = 88
Example
• An example of generating RSA Key pair is given below.
• For ease of understanding, the primes p & q taken here are small
values. Practically, these values are very high .
• Let two primes be p = 7 and q = 13.
• Thus, modulus n = pq = 7 x 13 = 91.
• Select e = 5, which is a valid choice since there is no number that is
common factor of 5 and p−1q−1 = 6 × 12 = 72, except for 1.
• The pair of numbers n,e = 91,5 forms the public key and can be
made available to anyone whom we wish to be able to send us
encrypted messages.
• Input p = 7, q = 13, and e = 5 to the Extended Euclidean Algorithm.
The output will be d = 29. Check that the d calculated is correct by
computing −
de = 29 × 5 = 145 = 1 mod 72
• Hence, public key is 91,5 and private keys is 91,29.
RSA Key Generation
Users of RSA must:
Determine two primes at random - p, q
Select either e or d and compute the other
Primes p,q must not be easily derived from
modulus n=p.q
Means must be sufficiently large
Typically guess and use probabilistic test
Exponents e, d are inverses, so use Inverse
algorithm to compute the other
RSA Security
Possible approaches to attacking RSA are:
Brute force key search - infeasible given size of
numbers
Mathematical attacks - based on difficulty of
computing ø(n), by factoring modulus n
Timing attacks - on running of decryption
Chosen cipher text attacks - given properties of
RSA
Timing Attacks
Developed by Paul Kocher in mid-1990’s
Exploit timing variations in operations
eg. multiplying by small vs large number
a 1 2 3 4 5 6 7 8 9 10 11
ga 2 4 8 16 32 64 128 256 512 1024 2048
ga mod p 2 4 8 5 10 9 7 3 6 1 2