(and 35)« previous | Friday, April 29, 2011 | next »
RSA Public Key Encryption
RSA stands for last names of inventors
RSA invented to solve problem of easy crackability of bitstreams. Basically It establishes a common secret between two parties. But before we begin…
Euler's Totient Function
Denoted by
When the product ranges over all primes
that divide
(prime factorization).
Example
Suppose
is a product of two distinct primes
and
, then:
Key Generation
Alice selects two distinct large (2000 bits) prime numbers
and
, and computes their product
.
She selects an odd integer
such that
She then computes positive integers
and
such that
.
- In other words,
data:image/s3,"s3://crabby-images/b71f2/b71f2b11c0960a19968b0d51589760a90a3b91dc" alt="{\displaystyle ed\equiv 1\mod {\varphi (n)}}"
She publishes the pair
(
and
are kept secret because factoring
is very difficult to do)
Encryption and Decryption
Overview: Suppose we want to send Alice a message. This message is chopped into blocks of 1024 bits and encrypt it using the public key. To decrypt it, Alice uses her private key.
Process:
- For simplicity, we'll assume that the message is encoded as an integer
in the range [2,n).
- If Bob wants to send the message
to Alice, he gets the public key
…
- and raises it to the
, modulo
: data:image/s3,"s3://crabby-images/f7d0a/f7d0a11b389190db26009aed7efb4f7ff9d5805c" alt="{\displaystyle C=M^{e}\mod {n}}"
- alice uses her secret key
and raises it to the
power:
data:image/s3,"s3://crabby-images/61910/619102c0879aee4aa9a9b16ea59e8fec9eee02ca" alt="{\displaystyle C^{d}\equiv M^{ed}\equiv M\mod {n}}"
Correctness of RSA
Why does this work?
Prerequisites:
The RSA Algorithm States:
- Let
be a product of two distinct primes
and
.
- Let
such that
.
Proof
By the Chinese Remainder Theorem, we can show that
since
are distinct primes.
By Fermat's Little Theorem,
Hence,