This is a java program to implement RSA algorithm. RSA is one of the first practicable public-key cryptosystems and is widely used for secure data transmission. In such a cryptosystem, the encryption key is public and differs from the decryption key which is kept secret. In RSA, this asymmetry is based on the practical difficulty of factoring the product of two large prime numbers, the factoring problem. RSA stands for Ron Rivest, Adi Shamir and Leonard Adleman.
Here is the source code of the Java Program to Implement the RSA Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.maixuanviet.setandstring;
import java.io.DataInputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.util.Random;
public class RSA
{
private BigInteger p;
private BigInteger q;
private BigInteger N;
private BigInteger phi;
private BigInteger e;
private BigInteger d;
private int bitlength = 1024;
private Random r;
public RSA()
{
r = new Random();
p = BigInteger.probablePrime(bitlength, r);
q = BigInteger.probablePrime(bitlength, r);
N = p.multiply(q);
phi = p.subtract(BigInteger.ONE).multiply(q.subtract(BigInteger.ONE));
e = BigInteger.probablePrime(bitlength / 2, r);
while (phi.gcd(e).compareTo(BigInteger.ONE) > 0 && e.compareTo(phi) < 0)
{
e.add(BigInteger.ONE);
}
d = e.modInverse(phi);
}
public RSA(BigInteger e, BigInteger d, BigInteger N)
{
this.e = e;
this.d = d;
this.N = N;
}
@SuppressWarnings("deprecation")
public static void main(String[] args) throws IOException
{
RSA rsa = new RSA();
DataInputStream in = new DataInputStream(System.in);
String teststring;
System.out.println("Enter the plain text:");
teststring = in.readLine();
System.out.println("Encrypting String: " + teststring);
System.out.println("String in Bytes: "
+ bytesToString(teststring.getBytes()));
// encrypt
byte[] encrypted = rsa.encrypt(teststring.getBytes());
// decrypt
byte[] decrypted = rsa.decrypt(encrypted);
System.out.println("Decrypting Bytes: " + bytesToString(decrypted));
System.out.println("Decrypted String: " + new String(decrypted));
}
private static String bytesToString(byte[] encrypted)
{
String test = "";
for (byte b : encrypted)
{
test += Byte.toString(b);
}
return test;
}
// Encrypt message
public byte[] encrypt(byte[] message)
{
return (new BigInteger(message)).modPow(e, N).toByteArray();
}
// Decrypt message
public byte[] decrypt(byte[] message)
{
return (new BigInteger(message)).modPow(d, N).toByteArray();
}
}
Output:
$ javac RSA.java $ java RSA Enter the plain text: MaiXuanViet Encrypting String: MaiXuanViet String in Bytes: 8397110102111117110100114121 Decrypting Bytes: 8397110102111117110100114121 Decrypted String: MaiXuanViet
Related posts:
Java Program to Implement Radix Sort
Functional Interface trong Java 8
Java Program to Solve the 0-1 Knapsack Problem
Spring 5 Functional Bean Registration
Spring Boot Configuration with Jasypt
Java Stream Filter with Lambda Expression
Check If a String Is Numeric in Java
Fixing 401s with CORS Preflights and Spring Security
Java Program to Check if a Matrix is Invertible
Java Program to Generate All Pairs of Subsets Whose Union Make the Set
Guide to the Synchronized Keyword in Java
Spring Boot - Cloud Configuration Client
Spring Boot with Multiple SQL Import Files
The Modulo Operator in Java
Spring Boot Gradle Plugin
Guide to the Volatile Keyword in Java
Java Program to Implement Hash Tables
Java Program to add two large numbers using Linked List
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Optional trong Java 8
Guide to java.util.concurrent.Locks
Java Program to Perform Polygon Containment Test
Java Program to Implement Bucket Sort
HttpClient Timeout
Exploring the Spring 5 WebFlux URL Matching
Java Program to Implement Miller Rabin Primality Test Algorithm
Spring Boot: Customize the Jackson ObjectMapper
Spring Security and OpenID Connect
Basic Authentication with the RestTemplate
Introduction to the Functional Web Framework in Spring 5
Spring Security 5 – OAuth2 Login
Java Program to Implement Strassen Algorithm