AES 需要限制 SEED 长度
文章目录
【注意】最后更新于 July 9, 2024,文中内容可能已过时,请谨慎使用。
写了一个工具类用来加密解密数据库的 app 字段
本地环境运行单测什么都没有任何问题,但是一到生产环境就出现 BUG。
这个的原因是因为线上环境没有支持 AES 算法的 Provider 需要通过改 ext 包下添加支持的第三方包或者引入第三方库解决。
我这边采用的是引入第三方库:
|
|
|
|
这样就解决了 No installed provider supports this key 的问题。
但是提到了测试环境,又出现了问题:
显示没有合法的 AES key
首先我先将 SEED 的长度设置到 16 个字符,本地没有问题但是测试环境仍然报错,我突然发现我的 SEED 会进行一次 SHA-256 算法的散列,随后他的字符数目会增加到 32 个。
我们需要明确一下本地环境和线上环境的不同:
- 本地:Jdk 安全目录含有 unlimit 的 jar 包,也就是支持 16 24 32 位的 key
- 线上:Jdk 安全目录只含有 limit 的 jar 包,只支持 16 位的 key
有两种解决方式 1。线上安装 unlimit 的 jar 包 2。使用 16 位的 key
因为线上是容器环境,比较难更改 jdk jar 包,所以采用第二种。
只需要将对 SEED 加密的散列算法改为 MD5 加密就行,因为 MD5 会将 SEED 转换为一个长度为 16 个字符的字符串。
|
|
文章作者 xiantang
上次更新 2024-07-09 (9ac8718e)