-1
我正在嘗試創建我的第一個公鑰加密程序,最近測試了代碼的加密部分失敗。這可能是一個非常簡單的錯誤,但暫時忍受着我。我嘗試加密單詞「hello」,並且該程序多次返回[D @ 34005e1的翻譯。下面是我的課程的代碼,任何幫助將不勝感激。RSA加密不正確加密
主營:
package MAE;
import java.util.Scanner;
import java.lang.Math;
public class Main
{
public static void main(String[] args)
{
Scanner Input = new Scanner(System.in);
int choice;
boolean exit = true;
while(exit == true)
{
System.out.println("Please select a option from the menu below.");
System.out.println("1. Generate Key");
System.out.println("2. Encrypt Message");
System.out.println("3. Decrypt Message");
System.out.println("4. Exit");
choice = Input.nextInt();
switch(choice)
{
case 1:
keyGen();
break;
case 2:
encrypt();
break;
case 3:
decrypt();
break;
case 4:
exit = false;
break;
}
}
}
public static void keyGen()
{
Scanner Input = new Scanner(System.in);
encryptionAlgorithm eKey = new encryptionAlgorithm();
System.out.println("Public Key-(" + eKey.getDValue() + ", " + eKey.getNValue() + ")");
System.out.println("Private Key-(" + eKey.getEValue() + ", " + eKey.getNValue() + ")");
}
public static void encrypt()
{
String alphabet[] = new String[] {"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", ".", " "};
Scanner Input =new Scanner(System.in);
System.out.println("Enter Encryption Key First Digit:");
double eKey1 = Input.nextDouble();
System.out.println("Enter Encryption Key Second Digit");
double eKey2 = Input.nextDouble();
Input.nextLine();
System.out.println("Enter message to Encrypt, omitting any puncuation besides periods.");
String message = Input.nextLine();
String messageChars[] = new String[message.length()];
int messageValues[] = new int[message.length()];
double previousValue = 0;
double messageEncrypted[] = new double[message.length()];
double tempval = 0;
for(int x = 0; x < message.length(); x++)
{
messageChars[x] = Character.toString(message.charAt(x));
}
for(int x = 0; x < message.length(); x++)
{
for(int y = 0; y < alphabet.length; y++)
{
if(messageChars[x].equals(alphabet[y]))
{
messageValues[x] = y;
}
}
}
for(int x = 0; x < messageValues.length; x++)
{
previousValue = (messageValues[x] - 1 * messageValues[x] + 1) % messageValues[x];
tempval = Math.pow(messageValues[x], eKey1);
messageEncrypted[x] = (tempval % eKey2) + previousValue;
}
for(int x = 0; x < messageEncrypted.length; x++)
{
System.out.println(messageEncrypted + ", ");
}
}
public static void decrypt()
{
}
}
encryptionAlgorithm:
package MAE;
import java.util.Scanner;
import java.util.Random;
public class encryptionAlgorithm
{
public static double p;
public static double q;
public static double n;
public static double r;
public static double k;
public static double eKey;
public static double dKey;
public encryptionAlgorithm()
{
Random random = new Random();
boolean isPPrime = true;
boolean isQPrime = true;
double d = 2;
Scanner Input = new Scanner(System.in);
System.out.println("Please enter a prime number. Larger numbers are more secure.");
p = Input.nextDouble();
do
{
isPPrime = true;
for(d = 2; d * d <= p && isPPrime == true; d++)
{
if(p % d == 0)
{
isPPrime = false;
}
}
if(isPPrime == false)
{
System.out.println("This number is not prime. Please enter another number.");
p = Input.nextDouble();
}
} while(isPPrime == false);
d = 2;
System.out.println("Please enter another prime number. Larger numbers are more secure.");
q = Input.nextDouble();
do
{
while(q == p)
{
System.out.println("This number is identical to the first entered number. Please enter another number.");
q = Input.nextDouble();
}
isQPrime = true;
for(d = 2; d * d <= q && isQPrime == true; d++)
{
if(q % d == 0)
{
isQPrime = false;
}
}
if(isQPrime == false)
{
System.out.println("This number is not prime. Please enter another number.");
q = Input.nextDouble();
}
} while(isQPrime == false);
n = p * q;
r = (p - 1) * (q - 1);
double x = r + 1;
float v = 2;
while(k == 0)
{
while(v * v <= x)
{
if(x % v == 0)
{
k = x;
}
v++;
}
x += r;
}
k += r * random.nextInt(3);
for(int c = 2; c <= k; c++)
{
if(k % c == 0)
{
eKey = c;
dKey = k/eKey;
}
}
}
public double getPValue()
{
return p;
}
public double getQValue()
{
return q;
}
public double getNValue()
{
return n;
}
public double getRValue()
{
return r;
}
public double getKValue()
{
return k;
}
public double getEValue()
{
return eKey;
}
public double getDValue()
{
return dKey;
}
}
使用不平凡的鍵,你會溢出雙精度,提供不正確的結果。您應該改用java.math.BigInteger。 –