首页 文章

如何在Java中加密时返回并显示RSA密文

提问于
浏览
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密码应该只是字母数字字符吗?如果没有,为什么裁判建议使用它?

1 回答

  • 0

    为什么选择base64?

    例如,如果您的消息转换为仅ASCII的管道,则base64编码的文本将承受二进制流不会发生的格式引发的更改 . 嵌入电子邮件,复制和粘贴等等也更容易 .

    Here's一个很好的答案,谈论base64的 Value .

    至于哪种方法是正确的 - 假设您正确编码和解码,字节流应该是等效的 .

相关问题