我最近将我的项目转移到了 AndroidX,在为应用程序实现指纹时,我正在使用 AndroidX 的 Biometric。
implementation 'androidx.biometric:biometric:1.0.0-alpha03'
当显示一个对话框以使用指纹进行身份验证时,该对话框将“取消”选项设置为否定按钮。
final BiometricPrompt.PromptInfo promptInfo = new BiometricPrompt.PromptInfo.Builder()
.setTitle("Log into App")
.setSubtitle("Please touch the fingerprint sensor to log you in")
.setDescription("Touch Sensor")
.setNegativeButtonText("Cancel".toUpperCase())
.build();
Required: Set the text for the negative button.
This would typically be used as a "Cancel" button, but may be also used
to show an alternative method for authentication,
such as screen that asks for a backup password.
因此,我可以说“使用密码”代替“取消”按钮,以提供另一种方法以防指纹失败,当用户单击它时,我可以显示另一个弹出对话框,让用户输入设备密码以帮助检索应用程序密码从密钥库。它是否正确 ?
但是,如果我没有设置密码来解锁手机,而是使用模式,会发生什么?
我看到如果我使用 android.hardware.biometrics.BiometricPrompt.Builder 而不是 androidx.biometric.BiometricPrompt.PromptInfo.Builder,它有一个方法https://developer.android.com/reference/android/hardware/biometrics/BiometricPrompt .Builder.html#setDeviceCredentialAllowed(boolean) 用于相同目的,让用户在指纹失败时使用其他方式进行身份验证。
有人可以帮我理解这一点吗?我如何使用 AndroidX 实现这一点,因为我的应用程序从 API 16 开始兼容。为什么 AndroidX 不使用这种回退方法?