KeyStore getKey()在Android中返回null

baì*_*baì 5 java security android keystore

我正在使用此代码将密钥存储到Android App中的KeyStore中:

SecretKeyFactory kf = SecretKeyFactory.getInstance("DES");
DESKeySpec keySpec = new DESKeySpec(key); // byte[] key
SecretKey skey = kf.generateSecret(keySpec);

KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());
ks.load(null, "ksPassword".toCharArray());

PasswordProtection pass = new PasswordProtection(
        "entryPassword".toCharArray());
KeyStore.SecretKeyEntry skEntry = new KeyStore.SecretKeyEntry(skey);
ks.setEntry("keyAlias", skEntry, pass);

FileOutputStream fos = ctx.getApplicationContext().openFileOutput("bs.keystore",
        Context.MODE_PRIVATE);
ks.store(fos, ksPassword);
fos.close();
Run Code Online (Sandbox Code Playgroud)

然后,在另一种方法中,我使用此代码来检索我存储的密钥,

FileInputStream fis = ctx.getApplicationContext().openFileInput("bs.keystore");
KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());
ks.load(fis, "ksPassword".toCharArray());
Key k = (SecretKey) ks.getKey(keyAlias, "entryPassword".toCharArray());
fis.close();
Run Code Online (Sandbox Code Playgroud)

但指令ks.getKey("keyAlias", "entryPassword".toCharArray())返回null.

我哪里错了?

baì*_*baì 6

好的,我终于明白了这个问题......

我使用该方法在密钥库中存储多个密钥.使用该代码ks.load(null, "ksPassword".toCharArray());每次都擦除以前的密钥(因为加载一个空的密钥库)并且只有最后一个密钥存储在密钥库中.

所以正确的代码是:

KeyStore ks = KeyStore.getInstance(KeyStore.getDefaultType());
try {
FileInputStream fis = ctx.getApplicationContext().openFileInput("bs.keystore");
ks.load(fis, ksPassword);
} catch(FileNotFoundException e) {
    ks.load(null, ksPassword);
}
Run Code Online (Sandbox Code Playgroud)

第一次执行该方法时,文件bs.keystore不存在,因此执行catch块中的代码.而是在下一次调用中,文件存在,新密钥将添加到密钥库.