我正在编写一个简单的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密码应该只是字母数字字符吗?如果没有,为什么裁判建议使用它?
1 回答
为什么选择base64?
例如,如果您的消息转换为仅ASCII的管道,则base64编码的文本将承受二进制流不会发生的格式引发的更改 . 嵌入电子邮件,复制和粘贴等等也更容易 .
Here's一个很好的答案,谈论base64的 Value .
至于哪种方法是正确的 - 假设您正确编码和解码,字节流应该是等效的 .