加载p12密钥库的BadPaddingException

Cha*_*lie 3 java

执行以下代码时:

    KeyStore ks = KeyStore.getInstance(storeType);
    ks.load(new FileInputStream(keyStore), storePassword.toCharArray());

    KeyManagerFactory kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
    kmf.init(ks, keyPassword.toCharArray());
Run Code Online (Sandbox Code Playgroud)

我得到一个例外:

java.security.UnrecoverableKeyException: Get Key failed: Given final block not properly padded. Such issues can arise if a bad key is used during decryption.
Caused by: javax.crypto.BadPaddingException: Given final block not properly padded. Such issues can arise if a bad key is used during decryption.
Run Code Online (Sandbox Code Playgroud)

这最初来自使用keytool转换为PKCS12密钥库的JKS密钥库.我尝试创建一个新的PKCS12密钥库,但没有运气.

Cha*_*lie 8

JKS支持使用两个密码,一个用于商店,一个用于密钥.PKCS12没有.使用keytool时,您会收到有关此问题的警告.

从新密钥库迁移到代码时,代码可能会继续使用旧密钥密码,在这种情况下密码不同.

Java 9提供了一个更好的异常消息,表明它可能在解密期间由坏密钥引起.

在这种情况下,请确保传入与商店密码匹配的密钥密码.