一、该问题的重现步骤是什么?
1. 使用org.springblade.test.CryptoKeyGenerator生成的AES 32位加密key
2. 前后端分别配置token的加密key
3.接口请求后端解析被加密的token时,经过跟踪发现报【java.security.InvalidKeyException: Illegal key size】错误
二、你期待的结果是什么?实际看到的又是什么?
三、你正在使用的是什么产品,什么版本?在什么操作系统上?
bladex,当前版本3.4.0,windows开发环境
四、请提供详细的错误堆栈信息,这很重要。
jdk1.8的jre的CryptoPermission类在判断加密key长度时,32位 > 16位(jdk1.8默认长度),导致报错,具体报错代码如下:
if (var2.maxKeySize <= this.maxKeySize) {
if (!this.impliesParameterSpec(var2.checkParam, var2.algParamSpec)) {
return false;
}
if (this.impliesExemptionMechanism(var2.exemptionMechanism)) {
return true;
}
}
五、若有更多详细信息,请在下面提供。
扫一扫访问 Blade技术社区 移动端