RSA Encryption and Decryption

The RSA algorithm for public-key encryption was originated by Ron Rivest, Adi Shamir, and Leonard Adleman at MIT in 1977. Several similar methods had been proposed by earlier workers. The algorithm is based on the fact that it is far more difficult to factor a product of two primes than it is to multiply the two primes. Even the most powerful modern supercomputers would require more time than the age of the universe to factor a 400-digit number. (This might change if quantum computers ever become operational.)
In this Demonstration, the RSA algorithm is simulated using much smaller randomly chosen prime numbers, and both less than 100. The public key, which is made freely available to Alice and all other users, consists of the two numbers and an exponent , which is an odd integer relatively prime to between 1 and . (Here is Euler's totient function, the number of positive integers less than and relatively prime to .) For simplicity, take and also limit messages to three letters, such as XYZ. This constitutes the plaintext and is converted into an integer using, for example, ASCII codes. The corresponding ciphertext is computed using .
Only the recipient Bob has access to the private key, which is an integer exponent , a modular inverse to such that . To determine , a codebreaker would need to find the prime factors of , which, as noted earlier, is hopefully impossible. The plaintext is recovered using . The method works since (mod ), with application of Fermat's little theorem. The public and private keys can periodically be changed according to some prearranged schedule.
By inputting the public key and the three-part ciphertext , Bob can recover the plaintext message.

(33 lines omitted)
comments
 
Powered by Wolfram Mathematica
Give us your feedback
Give us your feedback

Source page:




 often  occasionally  never

Note: Please do not include anything you consider confidential or proprietary. Your message and contact information may be shared with the author of any specific Demonstration for which you give feedback, but will not otherwise be published or distributed.
Privacy Policy »

Note: To run this Demonstration you need the free
Mathematica Player
or Mathematica 7+
Download or upgrade to Mathematica Player 7
I already have Mathematica Player or Mathematica 7+