2016-08-24 6 views
14

私はAndroidキーストアに保存しているRSA鍵ペアを使用してアプリケーション内のデータを暗号化しています。秘密鍵を取得するときチェーンがヌルです

私はPlayストアでNullPointerExceptionのを見てきたが、私はそれを再現することができませんでした。その後、

java.lang.NullPointerException: chain == null 
    at java.security.KeyStore$PrivateKeyEntry.<init>(KeyStore.java:1205) 
    at java.security.KeyStoreSpi.engineGetEntry(KeyStoreSpi.java:374) 
    at java.security.KeyStore.getEntry(KeyStore.java:644) 
    at MyClass.getKeyStoreEntry(MyClass.java:111) 

ソースコードの鍵ペアを作成する

Calendar start = Calendar.getInstance(); 
start.setTimeInMillis(0); 
Calendar end = Calendar.getInstance(); 
end.set(Calendar.YEAR, 3000); 

KeyPairGeneratorSpec.Builder keySpecBuilder = new KeyPairGeneratorSpec.Builder(context) 
    .setAlias(keyName) 
    .setSubject(new X500Principal("CN=" + keyName)) 
    .setSerialNumber(BigInteger.TEN) 
    .setStartDate(start.getTime()) 
    .setEndDate(end.getTime()) 
    .setKeySize(RSA_KEY_SIZE); 

KeyPairGeneratorSpec spec = keySpecBuilder.build(); 
KeyPairGenerator gen = KeyPairGenerator.getInstance("RSA", "AndroidKeyStore"); 
gen.initialize(spec); 
gen.generateKeyPair(); 

そして、

private KeyStore.PrivateKeyEntry getKeyStoreEntry() { 
    KeyStore keyStore = KeyStore.getInstance(ANDROID_KEY_STORE); 
    keyStore.load(null); 

    if (!keyStore.containsAlias(keyName)) { 
     throw new KeyNotFoundException(); 
    } 
    return (KeyStore.PrivateKeyEntry) keyStore.getEntry(keyName, null); 
} 

これは私がを使用した場合にのみ発生しますAPIレベル19-22の23+の実装は正常に動作します。

I do not have another key with the same nameまた、deleted the keyもありません。

+0

これであなたはこれまでどんな運がありましたか? –

+0

@RED_いいえ - 失敗した場合は古い実装に落ちてしまいました – AesSedai101

答えて

1

あなたは単にキーストアのバグに直面していると思います。たとえば、Android Security: The Forgetful Keystoreなどの記事を参照してください。 AndroidKeyStore deleted after changing screen lock typeのように、キーストアに関連するAndroidトラッカーには多数のバグレポートがあります。

+0

キーストアにキーが存在しない場合は、その場所の回避策を適用します(これは残念ながら問題ありません)。 – AesSedai101

関連する問題