-
Exception in thread "main" javax.crypto.BadPaddingException: Given final block not properly padded
-
at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
-
at com.sun.crypto.provider.SunJCE_f.b(DashoA13*..)
-
at com.sun.crypto.provider.AESCipher.engineDoFinal(DashoA13*..)
at javax.crypto.Cipher.doFinal(DashoA13*..
解决:
SecureRandom
实现完全随操作系统本身的內部状态,除非调用方在调用 getInstance 方法之后又调用了 setSeed 方法;该实现在 windows
上每次生成的 key 都相同,但是在 solaris 或部分 linux 系统上则不同。
-
//防止linux下 随机生成key
-
SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG" );
-
secureRandom.setSeed(keycontent.getBytes());
-
// 根据密钥初始化密钥生成器
-
kgen.init(keyNum, secureRandom);参考:https://blog.csdn.net/zhangyucen/article/details/44807559