AES:window/linux不同操作系统存在的坑(javax.crypto.BadPaddingException: Given final block not properly padded)

原始代码:


# 初始化秘钥

try {
KeyGenerator _generator = KeyGenerator.getInstance( "AES" );
_generator.init(128 , new SecureRandom(strKey.getBytes()));
return _generator.generateKey();
} catch (Exception e) {
throw new RuntimeException( " 初始化密钥出现异常 " );
}

问题描述:


Windows操作系统AES加解密正常,Linux系统加密正常,解密抛出如下异常:

javax.crypto.BadPaddingException: Given final block not properly padded

原因描述:


java.security.SecureRandom类在Windows系统中相同密码每次生成随机数都是相同的,然而在Linux系统中会生成不一致的情况。

解决方法:


try {

KeyGenerator _generator = KeyGenerator.getInstance( "AES" );
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(password.getBytes());

_generator .init(128, secureRandom);
return _generator.generateKey();
} catch (Exception e) {
throw new RuntimeException( " 初始化密钥出现异常 " );
}

指定秘钥生成规则即可解决不用操作系统AES解密的问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值