我正在编写一个简单的 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 密码是否应该仅使用字母数字字符?如果不是,为什么裁判建议使用它?