2013-12-10 105 views
-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; 
    } 
} 
+0

使用不平凡的鍵,你會溢出雙精度,提供不正確的結果。您應該改用java.math.BigInteger。 –

回答

1

這段代碼是根本錯誤的。首先你不能使用雙打。雙數不能保存超過64位的信息,並且當數字溢出時執行諸如電源等操作時會丟失信息。您還使用帶符號整數,所以充其量,您可以擁有絕對無用且可被破壞的RSA31在微秒。但即使使用RSA31,您也應該執行模指數,它不是指數後跟模數,因爲對於真正的RSA,當您使用大數字時,1024位表示指數的結果爲2^100位,而不是您的電腦可以存儲。在使用整數時,指數的結果也很容易溢出。 您的代碼中還存在其他問題,但首先您需要一些多精度整數庫,並使用模冪運算。