AES128解密:javax.crypto.badpaddingexception pad块损坏
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了AES128解密:javax.crypto.badpaddingexception pad块损坏,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1344字,纯文字阅读大概需要2分钟。
内容图文
![AES128解密:javax.crypto.badpaddingexception pad块损坏](/upload/InfoBanner/zyjiaocheng/764/ddc82b28bbd34107b12cb8ff018aed87.jpg)
我尝试解密从Web服务收到的加密数据.
加密使用AES 128完成.
我使用以下代码来解密数据:
public static String decrypt(String strToDecrypt)
{
try
{
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding"); //AES/CBC/PKCS7Padding
SecretKeySpec secretKey = new SecretKeySpec(AppConstants.AESEncryptionKey.getBytes("UTF8"), "AES");
int blockSize = cipher.getBlockSize();
cipher.init(Cipher.DECRYPT_MODE, secretKey, new IvParameterSpec(new byte[blockSize])); //new IvParameterSpec(new byte[16])
byte decBytes[] = cipher.doFinal(Base64.decode(strToDecrypt, 0));
// byte decBytes[] = cipher.doFinal(Base64.decodeBase64(strToDecrypt));
String decStr = new String(decBytes);
System.out.println("After decryption :" + decStr);
return decStr;
}
catch (Exception e)
{
System.out.println("Exception in decryption : " + e.getMessage());
}
return null;
}
在
cipher.doFinal()
我得到以下例外:
javax.crypto.badpaddingexception pad block corrupted
我经历了我的帖子,但最终没有解决方案.我被困在这里.
解决方法:
AES密钥应包含随机数据.如果将它们存储为String,则可能会丢失信息,尤其是在使用UTF-8等编码时.你的路线:
AppConstants.AESEncryptionKey.getBytes("UTF8")
使您在转换为字符串/从字符串转换过程中丢失数据的可能性很小.如果需要字符串,则使用十六进制,或者只将字符串存储为字节数组.
请注意,此答案并未指出任何与安全相关的提示.通常,您只想导出密钥或将它们存储在容器中.您也不想在不安全的渠道上使用CBC.
内容总结
以上是互联网集市为您收集整理的AES128解密:javax.crypto.badpaddingexception pad块损坏全部内容,希望文章能够帮你解决AES128解密:javax.crypto.badpaddingexception pad块损坏所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。