Java使用AES加密的时候没得问题,但是在解密的时候就出错了,一起来找找原因吧。
首先,Java运行的代码如下,使用AES加解密
Cipher cipher = Cipher.getInstance("AES/CBC/NOPadding");
//...
主要问题
可调试运行控制台抛出异常:
Cipher functions:OPENSSL_internal:WRONG_FINAL_BLOCK_LENGTH
❓看不懂英文?借助翻译工具吧
仔细看看,加密的结果字符串长度,没看出问题吧
SkBJS7W4VaQDCaHJdY97eeaZ6HdTJEyf2n9k/ovIECc=
💡再想办法,绕绕头,掉了几根头发后…
借助阅读工具看到,会发现多了一个容易忽略的换行符
SkBJS7W4VaQDCaHJdY97eeaZ6HdTJEyf2n9k/ovIECc=
\n
没想到真的是跟长度有关,复制的时候没有把换行符一起带上
其它问题
报错1
Wrong IV length: must be 16 bytes long
表示用于VI加解密的密钥字符串长度必须是16位
尝试填充字符串
报错2
IV not used in ECB mode
表示用于VI加解密不要使用ECB模式
尝试改成
Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
再不看懂英文就Out了



![[Android 四大组件] --- Activity](https://img-blog.csdnimg.cn/ed7722f2e08749dfade6a1b618b9ec16.png)




![[集创赛海云捷讯杯]全国二等奖经验分享](https://img-blog.csdnimg.cn/9ccaae55ba57441b8cfc0a068f484816.png)


![国民八路参考文献:[8]许少辉.乡村振兴战略下传统村落文化旅游设计[M]北京:中国建筑工业出版社,2022.](https://img-blog.csdnimg.cn/e56ee9e8456942778a703249ec8cf673.jpeg#pic_center)







