我正在编写一个在Android中使用RSA的程序。 我遇到了以下问题: 我已经获取了RSA密钥:
KeyPair kp = kpg.genKeyPair();
publicKey = kp.getPublic();
privateKey = kp.getPrivate();
使用加密函数对测试字符串进行加密:
String test ="test";
byte[] testbytes = test.getBytes();
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.ENCRYPT_MODE, publicKey);
byte[] cipherData = cipher.doFinal(testbytes);
String s = new String(cipherData);
Log.d("testbytes after encryption",s);
在解密函数中,我正在将数据解密回原始字符串。
Cipher cipher2 = Cipher.getInstance("RSA");
cipher2.init(Cipher.DECRYPT_MODE, privateKey);
byte[] plainData = cipher.doFinal(cipherData);
String p = new String(plainData);
Log.d("decrypted data is:",p);
日志中打印出来的 'p' 数据与原始字符串 "test" 不匹配。我在哪里做错了?
cipherData
将是一个类似随机的二进制字符串,因此仅使用原始字节(String s = new String(cipherData);
)将其转换为字符串可能会产生奇怪的结果。 - Nikolay Elenkov