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 Tarjan Algorithm
Java Program to Implement Hash Tables Chaining with List Heads
Mapping a Dynamic JSON Object with Jackson
Validations for Enum Types
Changing Annotation Parameters At Runtime
Spring Cloud – Securing Services
Batch Processing with Spring Cloud Data Flow
HttpClient 4 – Follow Redirects for POST
Spring @RequestParam Annotation
Constructor Injection in Spring with Lombok
Spring Boot - Database Handling
Guide to Java 8 groupingBy Collector
Spring Boot - Google OAuth2 Sign-In
Hướng dẫn Java Design Pattern – Adapter
Java Program to Check whether Directed Graph is Connected using DFS
Introduction to Java Serialization
Spring MVC Content Negotiation
Using a Mutex Object in Java
Lập trình đa luồng với CompletableFuture trong Java 8
Java Program to Create a Balanced Binary Tree of the Incoming Data
CharSequence vs. String in Java
Database Migrations with Flyway
Java Program to Check Whether Topological Sorting can be Performed in a Graph
Java Program to Implement Merge Sort Algorithm on Linked List
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
Spring Boot Annotations
Lớp Collectors trong Java 8
Java Program to Implement TreeSet API
Lớp HashMap trong Java
Introduction to Spring Data JDBC
Disable DNS caching
Practical Java Examples of the Big O Notation