0

我正在编写一个简单的 Java 程序来使用 Java 使用 DES 和 RSA 算法进行加密/解密。在 Java 中,为了使用函数加密和解密doFinal,我必须将消息(纯文本)转换为字节。我使用该功能.getBytes来做到这一点。以下是部分代码:

Cipher desCipher
// Create the cipher 
desCipher = Cipher.getInstance("DES/ECB/NoPadding");
desCipher.init(Cipher.ENCRYPT_MODE, myDesKey);
byte[] textEncrypted = desCipher.doFinal(msgBytes);

然后,将其返回为:

return new String(base64Cipher);

在这种情况下,我得到的密文看起来像奇怪的字符,例如:

Encrypted Message: °;zRfwجvë    ‏“ëثw‰ڑل7دM#¼7وm‡î¤

在一些互联网教程中,他们在返回密码之前使用了 Base64 编码,例如此参考: http ://techie-experience.blogspot.com/2012/10/encryption-and-decryption-using-aes.html

当我如下使用 Base64 时:

byte[] textEncrypted = desCipher.doFinal(msgBytes);

// converts to base64 for easier display.
byte[] base64Cipher = Base64.encodeBase64(textEncrypted);
return new String(base64Cipher);

密文以字母和数字字符显示为:

Encrypted Message: Xz93ODw3gEKm3hziPr0UJ+ed55nWLGpTR9uHjZjLwtg=

哪种方法是正确的?RSA 密码是否应该仅使用字母数字字符?如果不是,为什么裁判建议使用它?

4

1 回答 1

0

为什么选择base64?

base64 编码的文本将在格式引起的变化中幸存下来,而二进制流则不会——例如,如果您的消息通过仅 ASCII 的管道传输。它也更容易嵌入电子邮件、复制和粘贴等。

这是一个关于 base64 价值的好答案。

至于哪种方法是正确的——假设你正确编码和解码,字节流应该是等价的。

于 2013-10-27T21:06:26.137 回答