带有StrongBox的Android KeyStore:如何测试用户状态?

时间:2018-11-16 13:24:38

标签: android android-keystore android-9.0-pie

在Pixel 3上运行的Android API 28提供了对User Presence内部生成的密钥要求Android KeyStore的选项。但是,当使用该密钥创建签名时,我该如何实际测试用户的状态?我在文档中缺少什么吗?

KeyGenParameterSpec.Builder keyGenSpec = new KeyGenParameterSpec.Builder("alias", KeyProperties.PURPOSE_SIGN)
    .setDigests(KeyProperties.DIGEST_SHA256)
    .setKeySize(256)
    .setIsStrongBoxBacked(true)
    .setUserPresenceRequired(true);

KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("EC", "AndroidKeyStore");
keyPairGenerator.initialize(keyGenSpec.build());
keyPairGenerator.generateKeyPair();

KeyStore keyStore = KeyStore.getInstance("AndroidKeyStore");
keyStore.load(null, null);
PrivateKey privateKey = (PrivateKey) keyStore.getKey("alias", null);
Signature signature = Signature.getInstance("SHA256withECDSA");
signature.initSign(privateKey);
signature.update("Hello".getBytes(Charset.defaultCharset()));
byte[] sign = signature.sign();

该代码抛出android.security.KeyStoreException: -69,该翻译为PROOF_OF_PRESENCE_REQUIRED。我也尝试过将签名过程包装在BiometricPrompt中,但无济于事。

0 个答案:

没有答案