Understanding Cryptography - A Textbook For Students and Practitioners

Download as pdf or txt
Download as pdf or txt
You are on page 1of 29

Understanding Cryptography – A Textbook for

Students and Practitioners


by Christof Paar and Jan Pelzl

www.crypto-textbook.com

Chapter 6 – Introduction to
Public-Key Cryptography
ver. November 18, 2010

These slides were prepared by Timo Kasper and Christof Paar


Some legal stuff (sorry): Terms of Use

• The slides can used free of charge. All copyrights for the slides remain with
Christof Paar and Jan Pelzl.
• The title of the accompanying book “Understanding Cryptography” by
Springer and the author’s names must remain on each slide.
• If the slides are modified, appropriate credits to the book authors and the
book title must remain within the slides.
• It is not permitted to reproduce parts or all of the slides in printed form
whatsoever without written consent by the authors.

2/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

3/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

4/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Symmetric Cryptography revisited

Alice Bob

x eK(x) dK(y) x
y

K K

Two properties of symmetric (secret-key) crypto-systems:


• The same secret key K is used for encryption and decryption
• Encryption and Decryption are very similar (or even identical) functions

5/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Symmetric Cryptography: Analogy

K K

Safe with a strong lock, only Alice and Bob have a copy of the key
• Alice encrypts  locks message in the safe with her key
• Bob decrypts  uses his copy of the key to open the safe

6/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Symmetric Cryptography: Shortcomings
• Symmetric algorithms, e.g., AES or 3DES, are very secure, fast & widespread but:

• Key distribution problem: The secret key must be transported securely


• Number of keys: In a network, each pair of users requires an individual key

 n users in the network require keys, each user stores (n-1) keys

Example:
6 users (nodes)

6⋅5
= 15 keys (edges)
2

• Alice or Bob can cheat each other, because they have identical keys.
Example: Alice can claim that she never ordered a TV on-line from Bob (he could
have fabricated her order). To prevent this: „non-repudiation“
7/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

8/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Idea behind Asymmetric Cryptography

New Idea:

Use the „good old mailbox“ principle:

Everyone can drop a letter

But: Only the owner has the


correct key to open the box

1976: first publication of such an algorithm by Whitfield Diffie and Martin Hellman,and
also by Ralph Merkle.

9/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Asymmetric (Public-Key) Cryptography

Principle: “Split up” the key

Public Key (Kpub) Secret Key (Kpr)


(Encrypt) (Decrypt)

 During the key generation, a key pair Kpub and Kpr is computed

10/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Asymmetric Cryptography: Analogy

Safe with public lock and private lock:

(Kpub) (Kpr)

• Alice deposits (encrypts) a message with the - not secret - public key Kpub
• Only Bob has the - secret - private key Kpr to retrieve (decrypt) the message

11/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

12/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Basic Protocol for Public-Key Encryption

Alice Bob

KpubB (KpubB,KprB) = K

x
y=eKpubB(x) y

x=dKprB(y)

 Key Distribution Problem solved *

*) at least for now; public keys need to be authenticated, cf.Chptr. 13 of Understanding Cryptogr.
13/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
 Security Mechanisms of Public-Key Cryptography

Here are main mechanisms that can be realized with asymmetric cryptography:

• Key Distribution (e.g., Diffie-Hellman key exchange, RSA) without a pre-


shared secret (key)

• Nonrepudiation and Digital Signatures (e.g., RSA, DSA or ECDSA) to


provide message integrity

• Identification, using challenge-response protocols with digital signatures

• Encryption (e.g., RSA / Elgamal)


Disadvantage: Computationally very intensive
(1000 times slower than symmetric Algorithms!)

14/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Basic Key Transport Protocol 1/2

In practice: Hybrid systems, incorporating asymmetric and symmetric algorithms

1. Key exchange (for symmetric schemes) and digital signatures are performed
with (slow) asymmetric algorithms

2. Encryption of data is done using (fast) symmetric ciphers, e.g., block ciphers
or stream ciphers

15/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Basic Key Transport Protocol 2/2
Example: Hybrid protocol with AES as the symmetric cipher

Alice Bob
(KpubB,KprB) = K
KpubB

Choose random
symmetric key K Key Exchange
(asymmetric)

y1 = eKpubB(K) y1
K = dKprB(y1)

message x Data Encryption

y2 (symmetric)
y2 = AESK (x) x = AES-1K (y2)
16/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

17/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 How to build Public-Key Algorithms
Asymmetric schemes are based on a „one-way function“ f():
• Computing y = f(x) is computationally easy
• Computing x = f-1(y) is computationally infeasible

One way functions are based on mathematically hard problems.


Three main families:
• Factoring integers (RSA, ...):
Given a composite integer n, find its prime factors
(Multiply two primes: easy)

• Discrete Logarithm (Diffie-Hellman, Elgamal, DSA, …):


Given a, y and m, find x such that ax = y mod m
(Exponentiation ax : easy)

• Elliptic Curves (EC) (ECDH, ECDSA): Generalization of discrete logarithm

Note: The problems are considered mathematically hard, but no proof exists (so far).
18/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
 Key Lengths and Security Levels

Symmetric ECC RSA, DL Remark

64 Bit 128 Bit ≈ 700 Bit Only short term security


(a few hours or days)
80 Bit 160 Bit ≈ 1024 Bit Medium security
(except attacks from big
governmental institutions etc.)
128 Bit 256 Bit ≈ 3072 Bit Long term security
(without quantum computers)

• The exact complexity of RSA (factoring) and DL (Index-Calculus) is difficult to


estimate
• The existence of quantum computers would probably be the end for ECC, RSA & DL
(at least 2-3 decades away, and some people doubt that QC will ever exist)
19/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
Content of this Chapter

• Symmetric Cryptography Revisited


• Principles of Asymmetric Cryptography
• Practical Aspects of Public-Key Cryptography
• Important Public-Key Algorithms
• Essential Number Theory for Public-Key Algorithms

20/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Euclidean Algorithm 1/2

• Compute the greatest common divisor gcd (r0, r1) of two integers r0 and r1

• gcd is easy for small numbers:


1. factor r0 and r1
2. gcd = highest common factor

• Example:
r0 = 84 = 2 . 2 . 3 . 7
r1 = 30 = 2 . 3 . 5

 The gcd is the product of all common prime factors:


2 . 3 = 6 = gcd (30,84)

• But: Factoring is complicated (and often infeasible) for large numbers


21/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
 Euclidean Algorithm 2/2
• Observation: gcd (r0, r1) = gcd (r0 - r1, r1)
 Core idea:
• Reduce the problem of finding the gcd of two given numbers
to that of the gcd of two smaller numbers
• Repeat process recursively
• The final gcd (ri, 0) = ri is the answer to the original problem !

Example: gcd (r0, r1) for r0 = 27 and r1 = 21

• Note: very efficient method even for long numbers:


The complexity grows linearly with the number of bits

For the full Euclidean Algorithm see Chapter 6 in Understanding Cryptography.


22/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
 Extended Euclidean Algorithm 1/2
• Extend the Euclidean algorithm to find modular inverse of r1 mod r0
• EEA computes s,t, and the gcd :
• Take the relation mod r0

 Compare with the definition of modular inverse: t is the inverse of r1 mod r0

• Note that gcd (r0, r1) = 1 in order for the inverse to exist

• Recursive formulae to calculate s and t in each step


 „magic table“ for r, s, t and a quotient q to derive the inverse with pen and paper
(cf. Section 6.3.2 in Understanding Cryptography)

23/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Extended Euclidean Algorithm 2/2

Example:
• Calculate the modular Inverse of 12 mod 67:
• From magic table follows
• Hence 28 is the inverse of 12 mod 67.

• Check: 28 ⋅12 = 336 ≡ 1 mod 67 

For the full Extended Euclidean Algorithm see Chapter 6 in Understanding Cryptography.

24/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Euler‘s Phi Function 1/2

• New problem, important for public-key systems, e.g., RSA:


Given the set of the m integers {0, 1, 2, …, m -1},
How many numbers in the set are relatively prime to m ?

• Answer: Euler‘s Phi function Φ(m)

• Example for the sets {0,1,2,3,4,5} (m=6), and {0,1,2,3,4} (m=5)

 1 and 5 relatively prime to m=6,  Φ(5) = 4


hence Φ(6) = 2

• Testing one gcd per number in the set is extremely slow for large m.
25/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl
 Euler‘s Phi Function 2/2

• If canonical factorization of m known:


(where pi primes and ei positive integers)
• then calculate Phi according to the relation

• Phi especially easy for ei = 1, e.g., m = p . q  Φ(m) = (p-1) . (q-1)

• Example m = 899 = 29 . 31:


Φ(899) = (29-1) . (31-1) = 28 . 30 = 840

• Note: Finding Φ(m) is computationally easy if factorization of m is known


(otherwise the calculation of Φ(m) becomes computationally infeasible for large numbers)

26/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Fermat‘s Little Theorem

• Given a prime p and an integer a:


• Can be rewritten as

• Use: Find modular inverse, if p is prime. Rewrite to


• Comparing with definition of the modular inverse
 is the modular inverse modulo a prime p

Example: a = 2, p = 7


• Fermat‘s Little Theorem works only modulo a prime p

27/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Euler‘s Theorem

• Generalization of Fermat‘s little theorem to any integer modulus

• Given two relatively prime integers a and m :

• Example: m=12, a=5


1. Calculate Euler‘s Phi Function

2. Verify Euler‘s Theorem

• Fermat‘s little theorem = special case of Euler‘s Theorem


• for a prime p:
 Fermat:

28/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl


 Lessons Learned

• Public-key algorithms have capabilities that symmetric ciphers don’t have,


in particular digital signature and key establishment functions.

• Public-key algorithms are computationally intensive (a nice way of saying


that they are slow), and hence are poorly suited for bulk data encryption.

• Only three families of public-key schemes are widely used. This is


considerably fewer than in the case of symmetric algorithms.

• The extended Euclidean algorithm allows us to compute modular inverses


quickly, which is important for almost all public-key schemes.

• Euler’s phi function gives us the number of elements smaller than an integer
n that are relatively prime to n. This is important for the RSA crypto scheme.

29/29 Chapter 6 of Understanding Cryptography by Christof Paar and Jan Pelzl

You might also like