3

我试图理解 java 中的 RSA - 但我无法弄清楚为什么这段代码不打印“Hello, World”我试图通过生成密钥对来确保我理解正确,加密“Hello World”和解密它。我正忙着弄清楚我做错了什么

import java.security.*;
import java.math.BigInteger;
import java.io.ObjectOutputStream;
import java.io.ObjectInputStream;
import javax.crypto.spec.*;
import java.security.spec.*;
import java.io.BufferedOutputStream;
import java.io.BufferedInputStream;
import java.io.FileOutputStream;
import java.io.FileInputStream;
import java.io.IOException;
import javax.crypto.Cipher;

public class testrsa
{
 public static void main(String [] args)
 {
   try
   {
     byte[] cipherData, plainData;
     KeyPairGenerator kpg = KeyPairGenerator.getInstance("RSA");
     kpg.initialize(4096);
     KeyPair kp = kpg.genKeyPair();
     Key publicKey = kp.getPublic();
     Key privateKey = kp.getPrivate();

      Cipher cipher1 = Cipher.getInstance("RSA");
      cipher1.init(Cipher.ENCRYPT_MODE, publicKey);
      cipherData = cipher1.doFinal("Hello, Word".getBytes());

      Cipher cipher2 = Cipher.getInstance("RSA");
      cipher2.init(Cipher.DECRYPT_MODE, privateKey);
      plainData = cipher2.doFinal(cipherData);

     System.out.print(plainData.toString());

     }
     catch(Exception ex)
     {
        System.out.print(ex.toString());
     }

 }
}
4

1 回答 1

3

改变

System.out.print(plainData.toString());

System.out.print(new String(plainData));

你赢了!

解释

plainData, 的返回doFinalbyte[]. 您在使用该toString()方法(类似于[B@75589559)时看到的不是解密损坏,而是 Java 如何实现byte[]toString()方法。

在我建议的代码中,您正在使用您提供的字节创建一个新字符串——这就是您想要的。

于 2012-11-28T20:11:01.533 回答