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:
The Registration Process With Spring Security
A Guide to ConcurrentMap
Introduction to Spring Data JDBC
Guava CharMatcher
Spring Boot - Apache Kafka
Một số từ khóa trong Java
Java 9 Stream API Improvements
Java Copy Constructor
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Introduction to Spring Cloud Netflix – Eureka
Java Program to Describe the Representation of Graph using Adjacency Matrix
Java Program to Implement RoleUnresolvedList API
Java Program to Perform Left Rotation on a Binary Search Tree
Removing all Nulls from a List in Java
Java Program to Implement Patricia Trie
Java Program to Decode a Message Encoded Using Playfair Cipher
Guide to Java OutputStream
Java Program to Compute Determinant of a Matrix
Java Program to Implement EnumMap API
Introduction to Netflix Archaius with Spring Cloud
@Order in Spring
Create Java Applet to Simulate Any Sorting Technique
Java Program to Find All Pairs Shortest Path
Java Program to Implement HashTable API
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Returning Custom Status Codes from Spring Controllers
Java Program to Check whether Directed Graph is Connected using DFS
Check If a File or Directory Exists in Java
Spring Cloud AWS – EC2
Automatic Property Expansion with Spring Boot
Abstract class và Interface trong Java
HttpClient Connection Management