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