Java Cipher Encryption Guide
Java Cipher Encryption Guide
import java.util.*;
public class Main {
public static void main(String args[]) {
Scanner sc = new Scanner(System.in);
System.out.println(" Input the plaintext message : ");
String plaintext = sc.nextLine();
System.out.println(" Enter the value by which each character in the plaintext message gets
shifted : ");
int shift = sc.nextInt();
String ciphertext = "";
char alphabet;
for(int i=0; i < plaintext.length();i++)
{
alphabet = plaintext.charAt(i);
if(alphabet >= 'a' && alphabet <= 'z')
{
alphabet = (char) (alphabet + shift);
if(alphabet > 'z') {
alphabet = (char) (alphabet+'a'-'z'-1);
}
ciphertext = ciphertext + alphabet;
}
else if(alphabet >= 'A' && alphabet <= 'Z') {
alphabet = (char) (alphabet + shift);
if(alphabet > 'Z') {
alphabet = (char) (alphabet+'A'-'Z'-1);
}
ciphertext = ciphertext + alphabet;
}
else {
ciphertext = ciphertext + alphabet;
}
}
System.out.println(" Ciphertext : " + ciphertext);
}
}
OUTPUT:
Input the plaintext message :
HELLO
Enter the value by which each character in the plaintext message gets shifted :
5
Ciphertext : MJQQT
import java.util.Scanner;
public class Main{
static void decrypt(String encpt, String key) {
char[] encpt_arr=encpt.toCharArray();
char[] key_arr=key.toCharArray();
char[]
alpha={'A','B','C','D','E','F','G','H','I','K','L',
'M','N','O','P','Q','R','S','T','U','V','W','X'
,'Y','Z'};
char[][] table=new char[5][5];
int ctr=-1;
for(int i=0;i<key_arr.length;i++)
for(int j=0;j<25;j++)
if(key_arr[i]==alpha[j])
{
ctr++;
int round = ctr/5;
table[round][ctr%5]=alpha[j];
alpha[j]='0';
break;
}
for(int i=0;i<alpha.length;i++)
{
if(alpha[i]!='0')
{
ctr++;
int round = ctr/5;
table[round][ctr%5]=alpha[i];
}
}
System.out.println("\nThe Reference Table is:");
for(int i=0;i<5;i++)
{
for(int j=0;j<5;j++)
System.out.print(table[i][j]+" ");
System.out.println();
}
char[] any=new char[encpt_arr.length];
int any_ctr=0;
for(int i=0;i<encpt_arr.length;i=i+2)
{
int row1=0,row2=0,col1=0,col2=0;
for(int j=0;j<5;j++)
{
for(int k=0;k<5;k++)
{
if(encpt_arr[i]==table[j][k])
{
row1=j;
col1=k;
break;
}
}
}
for(int j=0;j<5;j++)
{
for(int k=0;k<5;k++)
{
if(encpt_arr[i+1]==table[j][k])
{
row2=j;
col2=k;
break;
}
}
}
if(row1==row2)
{
col1=(col1-1+5)%5;
col2=(col2-1+5)%5;
any[any_ctr++]=table[row1][col1];
any[any_ctr++]=table[row2][col2];
}
else if(col1==col2)
{
row1=(row1-1+5)%5;
row2=(row2-1+5)%5;
any[any_ctr++]=table[row1][col1];
any[any_ctr++]=table[row2][col2];
}
else if(row1!=row2 && col1!=col2)
{
int row=0,col=0;
row=row1;
col=col2;
any[any_ctr++]=table[row][col];
row=row2;
col=col1;
any[any_ctr++]=table[row][col];
}
else
{
}
}
System.out.print("\nThe Intermediate Text is: ");
for(int i=0;i<any_ctr;i++)
System.out.print(any[i]);
char[] decpt_arr=new char[100];
int decpt_arr_ctr=0;
for(int i=0;i<any_ctr;i++)
{
if(i==0)
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i==1 && any[i-1]==any[i+1] &&
any[i]=='X')
{
continue;
}
if(i==1 && any[i-1]!=any[i+1] &&
any[i]!='X')
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i==2 && any[i-1]==any[i+1] &&
any[i]=='X')
{
continue;
}
if(i==2 && any[i-1]!=any[i+1] &&
any[i]!='X')
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i!=any_ctr-2 && i!=any_ctr-1
&& any[i-1]==any[i+1] && any[i]=='X')
{
continue;
}
if(i!=any_ctr-2 && i!=any_ctr-1
&& any[i-1]==any[i+1] && any[i]!='X')
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i==any_ctr-2 && any[i-1]==any[i+1]
&& any[i]=='X')
{
continue;
}
if(i==any_ctr-2 && any[i-1]==any[i+1]
&& any[i]!='X')
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i==any_ctr-1 && i%2!=0 &&
any[i]=='X')
{
continue;
}
if(i==any_ctr-1 && any[i]!='X')
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
if(i==any_ctr-1 && i%2==0 &&
any[i]=='X')
{
continue;
}
if(i>=0)
{
decpt_arr[decpt_arr_ctr++]=any[i];
continue;
}
}
System.out.print("\n\nThe Decrypted Text is: ");
for(int i=0;i<decpt_arr_ctr;i++)
System.out.print(decpt_arr[i]);
}
public static void main(String[] args) {
String encpt;
System.out.print("Enter Ciphertext: ");
Scanner scanner = new Scanner(System.in);
encpt = scanner.nextLine();
String key;
System.out.print("Enter Key: ");
key = scanner.nextLine();
decrypt(encpt,key);
}
}
OUTPUT:
Enter Ciphertext: CFSUPM
Enter Key: MONARCHY
The Reference Table is:
MONAR
CHYBD
EFGIK
LPQST
UVWXZ
The Intermediate Text is: HELXLO
The Decrypted Text is: HELLO
5) HILL CIPHER
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
private static int[][] getKeyMatrix() {
Scanner sc = new Scanner(System.in);
System.out.println("Enter key matrix:");
String key = sc.nextLine();
double sq = Math.sqrt(key.length());
if (sq != (long) sq) {
System.out.println("Cannot Form a square matrix");
}
int len = (int) sq;
int[][] keyMatrix = new int[len][len];
int k = 0;
for (int i = 0; i < len; i++)
{
for (int j = 0; j < len; j++)
{
keyMatrix[i][j] = ((int) key.charAt(k)) - 97;
k++;
}
}
return keyMatrix;
}
private static void isValidMatrix(int[][] keyMatrix) {
int det = keyMatrix[0][0] * keyMatrix[1][1] - keyMatrix[0][1] * keyMatrix[1][0];
if(det == 0) {
throw new java.lang.Error("Det equals to zero, invalid key matrix!");
}
}
private static void isValidReverseMatrix(int[][] keyMatrix, int[][] reverseMatrix) {
int[][] product = new int[2][2];
product[0][0] = (keyMatrix[0][0]*reverseMatrix[0][0] + keyMatrix[0][1] * reverseMatrix[1][0])
% 26;
product[0][1] = (keyMatrix[0][0]*reverseMatrix[0][1] + keyMatrix[0][1] * reverseMatrix[1][1])
% 26;
product[1][0] = (keyMatrix[1][0]*reverseMatrix[0][0] + keyMatrix[1][1] * reverseMatrix[1][0])
% 26;
product[1][1] = (keyMatrix[1][0]*reverseMatrix[0][1] + keyMatrix[1][1] * reverseMatrix[1][1])
% 26;
if(product[0][0] != 1 || product[0][1] != 0 || product[1][0] != 0 || product[1][1] != 1) {
throw new java.lang.Error("Invalid reverse matrix found!");
}
}
private static int[][] reverseMatrix(int[][] keyMatrix) {
int detmod26 = (keyMatrix[0][0] * keyMatrix[1][1] - keyMatrix[0][1] * keyMatrix[1][0]) % 26;
int factor;
int[][] reverseMatrix = new int[2][2];
for(factor=1; factor < 26; factor++)
{
if((detmod26 * factor) % 26 == 1)
{
break;
}
}
reverseMatrix[0][0] = keyMatrix[1][1] * factor % 26;
reverseMatrix[0][1] = (26 - keyMatrix[0][1]) * factor % 26;
reverseMatrix[1][0] = (26 - keyMatrix[1][0]) * factor % 26;
reverseMatrix[1][1] = keyMatrix[0][0] * factor % 26;
return reverseMatrix;
}
private static void echoResult(String label, int adder, ArrayList<Integer> phrase) {
int i;
System.out.print(label);
for(i=0; i < phrase.size(); i += 2) {
System.out.print(Character.toChars(phrase.get(i) + (64 + adder)));
System.out.print(Character.toChars(phrase.get(i+1) + (64 + adder)));
if(i+2 <phrase.size()) {
System.out.print("-");
}
}
System.out.println();
}
public static void encrypt(String phrase, boolean alphaZero)
{
int i;
int adder = alphaZero ? 1 : 0;
int[][] keyMatrix;
ArrayList<Integer> phraseToNum = new ArrayList<>();
ArrayList<Integer> phraseEncoded = new ArrayList<>();
phrase = phrase.replaceAll("[^a-zA-Z]","").toUpperCase();
if(phrase.length() % 2 == 1) {
phrase += "Q";
}
keyMatrix = getKeyMatrix();
isValidMatrix(keyMatrix);
for(i=0; i < phrase.length(); i++) {
phraseToNum.add(phrase.charAt(i) - (64 + adder));
}
for(i=0; i < phraseToNum.size(); i += 2) {
int x = (keyMatrix[0][0] * phraseToNum.get(i) + keyMatrix[0][1] * phraseToNum.get(i+1)) %
26;
int y = (keyMatrix[1][0] * phraseToNum.get(i) + keyMatrix[1][1] * phraseToNum.get(i+1)) %
26;
phraseEncoded.add(alphaZero ? x : (x == 0 ? 26 : x ));
phraseEncoded.add(alphaZero ? y : (y == 0 ? 26 : y ));
}
echoResult("Encoded phrase: ", adder, phraseEncoded);
}
public static void decrypt(String phrase, boolean alphaZero)
{
int i, adder = alphaZero ? 1 : 0;
int[][] keyMatrix, revKeyMatrix;
ArrayList<Integer> phraseToNum = new ArrayList<>();
ArrayList<Integer> phraseDecoded = new ArrayList<>();
phrase = phrase.replaceAll("[^a-zA-Z]","").toUpperCase();
keyMatrix = getKeyMatrix();
isValidMatrix(keyMatrix);
for(i=0; i < phrase.length(); i++) {
phraseToNum.add(phrase.charAt(i) - (64 + adder));
}
revKeyMatrix = reverseMatrix(keyMatrix);
isValidReverseMatrix(keyMatrix, revKeyMatrix);
for(i=0; i < phraseToNum.size(); i += 2) {
phraseDecoded.add((revKeyMatrix[0][0] * phraseToNum.get(i) + revKeyMatrix[0][1] *
phraseToNum.get(i+1)) % 26);
phraseDecoded.add((revKeyMatrix[1][0] * phraseToNum.get(i) + revKeyMatrix[1][1] *
phraseToNum.get(i+1)) % 26);
}
echoResult("Decoded phrase: ", adder, phraseDecoded);
}
public static void main(String[] args) {
String opt, phrase;
byte[] p;
Scanner sc = new Scanner(System.in);
System.out.println("Hill Cipher Implementation (2x2)");
System.out.println("-------------------------");
System.out.println("1. Encrypt text (A=0,B=1,...Z=25)");
System.out.println("2. Decrypt text (A=0,B=1,...Z=25)");
System.out.println();
System.out.println("Type any other character to exit");
System.out.println();
System.out.print("Select your choice: ");
opt = sc.nextLine();
switch (opt)
{
case "1":
System.out.print("Enter phrase to encrypt: ");
phrase = sc.nextLine();
encrypt(phrase, true);
break;
case "2":
System.out.print("Enter phrase to decrypt: ");
phrase = sc.nextLine();
decrypt(phrase, true);
break;
}
}
}
OUTPUT:
Hill Cipher Implementation (2x2)
-------------------------
1. Encrypt text (A=0,B=1,...Z=25)
2. Decrypt text (A=0,B=1,...Z=25)
6) RSA :
import java.math.*;
import java.util.*;
class Main {
public static void main(String args[])
{
Scanner o = new Scanner(System.in);
int n, z, d = 0, e, i;
System.out.println("Enter number to be encrypted");
Integer msg = o.nextInt();
double c;
BigInteger msgback;
System.out.println("Enter first prime number-p");
Integer p = o.nextInt();
System.out.println("Enter second prime number-q");
Integer q = o.nextInt();
n = p * q;
z = (p - 1) * (q - 1);
System.out.println("the value of z = " + z);
for (e = 2; e < z; e++) {
if (gcd(e, z) == 1) {
break;
}
}
System.out.println("the value of e = " + e);
for (i = 0; i <= 9; i++) {
int x = 1 + (i * z);
if (x % e == 0) {
d = x / e;
break;
}
}
System.out.println("the value of d = " + d);
c = (Math.pow(msg, e)) % n;
System.out.println("Encrypted message is : " + c);
BigInteger N = BigInteger.valueOf(n);
BigInteger C = BigDecimal.valueOf(c).toBigInteger();
msgback = (C.pow(d)).mod(N);
System.out.println("Decrypted message is : "+ msgback);
}
static int gcd(int e, int z)
{
if (e == 0)
return z;
else
return gcd(z % e, e);
}
}
OUTPUT:
Enter number to be encrypted
20
Enter first prime number-p
3
Enter second prime number-q
7
the value of z = 12
the value of e = 5
the value of d = 5
Encrypted message is : 20.0
Decrypted message is : 20
7) DIFFE HELLMANN:
import java.util.*;
class Main{
private static long power(long a, long b, long p)
{
if (b == 1)
return a;
else
return (((long)Math.pow(a, b)) % p);
}
public static void main(String[] args)
{
long P, G, x, a, y, b, ka, kb;
Scanner sc = new Scanner(System.in);
System.out.println("Enter public key of alice-P");
P = sc.nextInt();
System.out.println("Enter public key of bob-G");
G = sc.nextInt();
System.out.println("Enter alice private key:");
a = sc.nextInt();
x = power(G, a, P);
System.out.println("Enter bob private key:");
b = sc.nextInt();
y = power(G, b, P);
ka = power(y, a, P);
kb = power(x, b, P);
System.out.println("Secret key for the Alice is:" + ka);
System.out.println("Secret key for the Bob is:" + kb);
}
}
OUTPUT:
Enter public key of alice-P
23
Enter public key of bob-G
9
Enter alice private key:
4
Enter bob private key:
3
Secret key for the Alice is:9
Secret key for the Bob is:9
8) DES :
import java.util.*;
class Main {
private static class DES {
int[] IP = { 58, 50, 42, 34, 26, 18,
10, 2, 60, 52, 44, 36, 28, 20,
12, 4, 62, 54, 46, 38,
30, 22, 14, 6, 64, 56,
48, 40, 32, 24, 16, 8,
57, 49, 41, 33, 25, 17,
9, 1, 59, 51, 43, 35, 27,
19, 11, 3, 61, 53, 45,
37, 29, 21, 13, 5, 63, 55,
47, 39, 31, 23, 15, 7 };
int[] IP1 = { 40, 8, 48, 16, 56, 24, 64,
32, 39, 7, 47, 15, 55,
23, 63, 31, 38, 6, 46,
14, 54, 22, 62, 30, 37,
5, 45, 13, 53, 21, 61,
29, 36, 4, 44, 12, 52,
20, 60, 28, 35, 3, 43,
11, 51, 19, 59, 27, 34,
2, 42, 10, 50, 18, 58,
26, 33, 1, 41, 9, 49,
17, 57, 25 };
int[] PC1 = { 57, 49, 41, 33, 25,
17, 9, 1, 58, 50, 42, 34, 26,
18, 10, 2, 59, 51, 43, 35, 27,
19, 11, 3, 60, 52, 44, 36, 63,
55, 47, 39, 31, 23, 15, 7, 62,
54, 46, 38, 30, 22, 14, 6, 61,
53, 45, 37, 29, 21, 13, 5, 28,
20, 12, 4 };
int[] PC2 = { 14, 17, 11, 24, 1, 5, 3,
28, 15, 6, 21, 10, 23, 19, 12,
4, 26, 8, 16, 7, 27, 20, 13, 2,
41, 52, 31, 37, 47, 55, 30, 40,
51, 45, 33, 48, 44, 49, 39, 56,
34, 53, 46, 42, 50, 36, 29, 32 };
int[] EP = { 32, 1, 2, 3, 4, 5, 4,
5, 6, 7, 8, 9, 8, 9, 10,
11, 12, 13, 12, 13, 14, 15,
16, 17, 16, 17, 18, 19, 20,
21, 20, 21, 22, 23, 24, 25,
24, 25, 26, 27, 28, 29, 28,
29, 30, 31, 32, 1 };
int[] P = { 16, 7, 20, 21, 29, 12, 28,
17, 1, 15, 23, 26, 5, 18,
31, 10, 2, 8, 24, 14, 32,
27, 3, 9, 19, 13, 30, 6,
22, 11, 4, 25 };
int[][][] sbox = {
{ { 14, 4, 13, 1, 2, 15, 11, 8, 3, 10, 6, 12, 5, 9, 0, 7 },
{ 0, 15, 7, 4, 14, 2, 13, 1, 10, 6, 12, 11, 9, 5, 3, 8 },
{ 4, 1, 14, 8, 13, 6, 2, 11, 15, 12, 9, 7, 3, 10, 5, 0 },
{ 15, 12, 8, 2, 4, 9, 1, 7, 5, 11, 3, 14, 10, 0, 6, 13 } },
9) DIGITAL SIGNATURE:
import java.security.*;
import java.util.*;
public class Main{
public static void main(String args[]) throws Exception{
Scanner sc = new Scanner(System.in);
System.out.println("enter text");
String msg = sc.nextLine();
KeyPairGenerator KeyPairGen = KeyPairGenerator.getInstance("DSA");
KeyPairGen.initialize(2048);
KeyPair pair = KeyPairGen.generateKeyPair();
PrivateKey privKey = pair.getPrivate();
Signature sign = Signature.getInstance("SHA256withDSA");
sign.initSign(privKey);
byte[] bytes = "msg".getBytes();
sign.update(bytes);
byte[] signature = sign.sign();
System.out.println("Digital signatue for given text is :"+new String(signature,"UTF8"));
}
}
OUTPUT:
enter text
HIHOWAREYOU
Digital signatue for given text is :0<A!
Z�NJW�.�9����H�F1��H��K�F�m�Հ$8H�W���?��1�q��/��"
10) MD5:
import java.math.BigInteger;
import java.security.*;
import java.util.*;
public class Main{
public static String getMd5(String input)
{
try {
MessageDigest md = MessageDigest.getInstance("MD5");
byte[] messageDigest = md.digest(input.getBytes());
BigInteger no = new BigInteger(1, messageDigest);
String hashtext = no.toString(16);
while (hashtext.length() < 32) {
hashtext = "0" + hashtext;
}
return hashtext;
}
catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
}
public static void main(String args[]) throws NoSuchAlgorithmException
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter message");
String s = sc.nextLine();
System.out.println("Your HashCode Generated by MD5 is: " + getMd5(s));
}
}
OUTPUT:
Enter message
helloworld
Your HashCode Generated by MD5 is: fc5e038d38a57032085441e7fe7010b0
11) SHA:
import java.math.BigInteger;
import java.security.*;
import java.util.*;
public class Main{
public static String encryptThisString(String input)
{
try {
MessageDigest md = MessageDigest.getInstance("SHA-1");
byte[] messageDigest = md.digest(input.getBytes());
BigInteger no = new BigInteger(1, messageDigest);
String hashtext = no.toString(16);
while (hashtext.length() < 32) {
hashtext = "0" + hashtext;
}
return hashtext;
}
catch (NoSuchAlgorithmException e) {
throw new RuntimeException(e);
}
}
public static void main(String args[]) throws NoSuchAlgorithmException
{
Scanner sc = new Scanner(System.in);
System.out.println("HashCode Generated by SHA-1 for: ");
String s1 = sc.nextLine();
System.out.println("\n" + s1 + " : " + encryptThisString(s1));
}
}
OUTPUT:
HashCode Generated by SHA-1 for:
helloworld
helloworld : 6adfb183a4a2c94a2f92dab5ade762a47889a5a1
import java.util.*;
class RailFenceBasic{
int depth;
String Encryption(String plainText,int depth)throws Exception
{
int r=depth,len=plainText.length();
int c=len/depth;
char mat[][]=new char[r][c];
int k=0;
String cipherText="";
String plainText="";
return plainText;
}
}
class Main{
public static void main(String args[])throws Exception
{
RailFenceBasic rf=new RailFenceBasic();
Scanner scn=new Scanner(System.in);
int depth;
String plainText,cipherText,decryptedText;
cipherText=rf.Encryption(plainText,depth);
System.out.println("Encrypted text is:\n"+cipherText);
decryptedText=rf.Decryption(cipherText, depth);
}
}
OUTPUT:
Enter plain text:
helloworld
Enter depth for Encryption:
2
Encrypted text is:
hloolelwrd
Decrypted text is:
Helloworld
System.out.print("Enter Key:");
String key = scan.next();
System.out.println(encryptCT(key, text).toUpperCase());
break;
case 2:
System.out.print("Enter Encrypted String:");
text = scan.next();
System.out.print("Enter Key:");
key = scan.next();
System.out.println(decryptCT(key, text));
break;
default:
break;
}
}
public static String encryptCT(String key, String text) {
int[] arrange = arrangeKey(key);
int lenkey = arrange.length;
int lentext = text.length();
int row = (int) Math.ceil((double) lentext / lenkey);
char[][] grid = new char[row][lenkey];
int z = 0;
for (int x = 0; x < row; x++) {
for (int y = 0; y < lenkey; y++) {
if (lentext == z) {
// at random alpha for trailing null grid
grid[x][y] = RandomAlpha();
z--;
} else {
grid[x][y] = text.charAt(z);
}
z++;
}
}
String enc = "";
for (int x = 0; x < lenkey; x++) {
for (int y = 0; y < lenkey; y++) {
if (x == arrange[y]) {
for (int a = 0; a < row; a++) {
enc = enc + grid[a][y];
}
}
}
}
return enc;
}
public static String decryptCT(String key, String text) {
int[] arrange = arrangeKey(key);
int lenkey = arrange.length;
int lentext = text.length();
int row = (int) Math.ceil((double) lentext / lenkey);
String regex = "(?<=\\G.{" + row + "})";
String[] get = text.split(regex);
char[][] grid = new char[row][lenkey];
for (int x = 0; x < lenkey; x++) {
for (int y = 0; y < lenkey; y++) {
if (arrange[x] == y) {
for (int z = 0; z < row; z++) {
grid[z][y] = get[arrange[y]].charAt(z);
}
}
}
}
String dec = "";
for (int x = 0; x < row; x++) {
for (int y = 0; y < lenkey; y++) {
dec = dec + grid[x][y];
}
}
return dec;
}
public static char RandomAlpha() {
//generate random alpha for null space
Random r = new Random();
return (char)(r.nextInt(26) + 'a');
}
public static int[] arrangeKey(String key) {
//arrange position of grid
String[] keys = key.split("");
Arrays.sort(keys);
int[] num = new int[key.length()];
for (int x = 0; x < keys.length; x++) {
for (int y = 0; y < key.length(); y++) {
if (keys[x].equals(key.charAt(y) + "")) {
num[y] = x;
break;
}
}
}
return num;
}
}
OUTPUT:
1. Encryt 2.Decrypt : 1
Enter String:hellogoodmorning
Enter Key:31452
EORXOMNGHGOGLONWLDIT
1. Encryt 2.Decrypt : 2
Enter Encrypted String:EORXOMNGHGOGLONWLDIT
Enter Key:31452
HELLOGOODMORNINGXWTG