BadPaddingException: Given final block not properly padded 异常解决

本文记录了一次使用Spring框架EncryptionUtils工具类进行加密解密过程中遇到的问题及解决方案。问题表现为解密后的字符串出现乱码且与原字符串不符。经过排查发现是由于未对加密后的字符串进行URL编码处理,导致在传输过程中特殊字符被错误解析。通过增加URLEncoder.encode方法解决了该问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天项目在用Spring的EncryptionUtils加密解密时抛出这个异常,看了下异常日志,是在解密的时候抛出的,再看解密代码。


private final String ENCYPTION_KEY = "9849844146badfasdf97892345";



//加密

String loginName="aaa@111.com";


EncryptionUtils.encrypt(ENCYPTION_KEY, loginName);


生成加密字符串unique="jCLR5xpzSeSREmTt+ ZgcnA==" 忘记密码模板


//解密

String name = EncryptionUtils.decrypt(ENCYPTION_KEY, unique);


debug一下,发现unique="jCLR5xpzSeSREmTt ZgcnA==","+"不见了,name也出现了乱码,不等于aaa@111.com了,


问了老大一下,发现原因,原来没有对加密字符串进行编码,导致+变成空的,改正加密代码


java.net.URLEncoder.encode(EncryptionUtils.encrypt(ENCYPTION_KEY, loginName), "UTF-8");


最终生成unique="jCLR5xpzSeSREmTt% ZgcnA==";  


+号变成%分号了,解密,一切正常!!!

 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值