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 Bubble Sort
Lập trình đa luồng với CompletableFuture trong Java 8
Spring Boot - Hystrix
Java Program to Implement Cartesian Tree
Generic Constructors in Java
How to use the Spring FactoryBean?
Hướng dẫn Java Design Pattern – Null Object
Constructor Injection in Spring with Lombok
Converting Java Date to OffsetDateTime
Java 8 Collectors toMap
Injecting Prototype Beans into a Singleton Instance in Spring
Anonymous Classes in Java
@Lookup Annotation in Spring
Compact Strings in Java 9
Các kiểu dữ liệu trong java
Java Program to Implement Counting Sort
Primitive Type Streams in Java 8
Java Program to Implement Hash Tables with Quadratic Probing
Concatenating Strings In Java
An Intro to Spring Cloud Security
Java Program to Implement Sparse Matrix
Thực thi nhiều tác vụ cùng lúc như thế nào trong Java?
Java Program to Implement PriorityQueue API
Comparing Arrays in Java
Guide to the Fork/Join Framework in Java
Java Program to add two large numbers using Linked List
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Java Program to Implement the String Search Algorithm for Short Text Sizes
How to Delay Code Execution in Java
New Features in Java 8
Guava – Join and Split Collections
Java Program to Check the Connectivity of Graph Using DFS