Java AES加密和解密

Java AES加密和解密,第1张

Java AES加密和解密

如果对于块密码,您将不使用

Cipher
包含填充方案的转换,则需要使明文中的字节数为该密码的块大小的整数倍。

因此,要么将纯文本填充到16字节的倍数(即AES块大小),要么在创建

Cipher
对象时指定填充方案。例如,您可以使用:

Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");

除非您有充分的理由不这样做,否则请使用JCE实现中已包含的填充方案。他们考虑了许多微妙和极端的情况,否则您将不得不自己意识到和应对这些情况。


好的,您的第二个问题是您

String
用来保存密文。

一般来说,

String s = new String(someBytes);byte[] retrievedBytes = s.getBytes();

不会

someBytes
retrievedBytes
是相同的。

如果您希望/必须将密文保存在中

String
,请先对密文字节进行base64编码,然后
String
从base64编码的字节中构造。然后,当您解密时,将从
getBytes()
中获取base64编码的字节
String
,然后对它们进行base64解码以获取真实的密文,然后对其进行解密。

出现此问题的原因是,大多数(全部?)字符编码都无法将任意字节映射到有效字符。因此,当您

String
从密文创建密码时,
String
构造函数(使用字符编码将字节转换为字符)本质上必须丢弃一些字节,因为它对它们毫无意义。因此,当您从字符串中获取字节时,它们与您放入字符串中的字节不同。

在Java(以及通常在现代编程中)中,除非绝对知道要处理ASCII,否则不能假定一个字符=一个字节。这就是为什么要从任意字节构建字符串时需要使用base64(或类似的东西)的原因。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5499739.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-12
下一篇 2022-12-12

发表评论

登录后才能评论

评论列表(0条)

保存