指紋驗證登錄開發流程詳解
前言
指紋登錄可以實現應用的快捷登錄,在Android6.0谷歌才提供統一指紋SDK接口
今天我們來介紹下指紋登錄功能;
一、app里指紋登錄介紹
指紋識別是Android6.0以上就開始支持的一個功能,并且類也不多,主要就是FingerprintManager還有它里面三個內部類(AuthenticationCallback、AuthenticationResult、CryptoObject);
指紋數據是在手機的設置里面,不是存到自己寫的APP的;
指紋識別就只能識別,而不能在APP中錄入指紋,想錄入指紋可以,自己要到手機設置里面的指紋功能自己去添加,指紋識別功能能做的就是把用戶放到感應區的指紋數據與手機設置里面的已錄入的指紋數據進行比對,再執行成功失敗的回調,僅此而已;
二、指紋登錄步驟詳解
1、申請權限
Android清單文件中的指紋的權限是
- <uses-permission android:name="android.permission.USE_FINGERPRINT"/>
2、驗證手機是否支持指紋
- FingerprintManagerCompat提供了三個方法:
- isHardwareDetected() 判斷是否有硬件支持
- isKeyguardSecure() 判斷是否設置鎖屏,因為一個手機最少要有兩種登錄方式
hasEnrolledFingerprints() 判斷系統中是否添加至少一個指紋
- /**
- * 判斷是否支持指紋識別
- */
- public static boolean supportFingerprint(Context mContext) {
- if (Build.VERSION.SDK_INT < 23) {
- Toast.makeText(mContext, "您的系統版本過低,不支持指紋功能", Toast.LENGTH_SHORT).show();
- return false;
- } else {
- KeyguardManager keyguardManager = mContext.getSystemService(KeyguardManager.class);
- FingerprintManagerCompat fingerprintManager = FingerprintManagerCompat.from(mContext);
- if (!fingerprintManager.isHardwareDetected()) {
- Toast.makeText(mContext, "您的系統版本過低,不支持指紋功能", Toast.LENGTH_SHORT).show();
- return false;
- } else if (keyguardManager != null && !keyguardManager.isKeyguardSecure()) {
- Toast.makeText(mContext, "您的手機不支持指紋功能", Toast.LENGTH_SHORT).show();
- return false;
- } else if (!fingerprintManager.hasEnrolledFingerprints()) {
- Toast.makeText(mContext, "您至少需要在系統設置中添加一個指紋", Toast.LENGTH_SHORT).show();
- return false;
- }
- }
- return true;
- }
3、生成一個對稱加密的key
- val DEFAULT_KEY_NAME = "default_key"
- lateinit var keyStore: KeyStore
- private fun initKey() {
- keyStore = KeyStore.getInstance("AndroidKeyStore")
- keyStore.load(null)
- val keyGenerator =
- KeyGenerator.getInstance(KeyProperties.KEY_ALGORITHM_AES, "AndroidKeyStore")
- val builder = KeyGenParameterSpec.Builder(DEFAULT_KEY_NAME,
- KeyProperties.PURPOSE_ENCRYPT or KeyProperties.PURPOSE_DECRYPT)
- .setBlockModes(KeyProperties.BLOCK_MODE_CBC)
- .setUserAuthenticationRequired(true)
- .setEncryptionPaddings(KeyProperties.ENCRYPTION_PADDING_PKCS7)
- keyGenerator.init(builder.build())
- keyGenerator.generateKey()
- }
4、生成一個Cipher對象
- private fun initCipher(mContext: Context?) {
- val key = keyStore.getKey(DEFAULT_KEY_NAME, null) as SecretKey
- val cipher = Cipher.getInstance(KeyProperties.KEY_ALGORITHM_AES + "/"
- + KeyProperties.BLOCK_MODE_CBC + "/"
- + KeyProperties.ENCRYPTION_PADDING_PKCS7)
- cipher.init(Cipher.ENCRYPT_MODE, key)
- }
5、開啟指紋驗證
- private void showFingerPrintDialog(Context context, Cipher cipher) {
- FingerprintManagerCompat fingerprintManagerCompat = FingerprintManagerCompat.from(context);
- FingerprintManagerCompat.CryptoObject cryptoObject = new FingerprintManagerCompat.CryptoObject(cipher);
- CancellationSignal mCancellationSignal = new CancellationSignal();
- //識別過程中可以手動取消指紋識別
- //mCancellationSignal.cancel();
- fingerprintManagerCompat.authenticate(cryptoObject, 0, mCancellationSignal, new MyCallBack(), null);
- }
6、指紋驗證回調
- public class MyCallBack extends FingerprintManagerCompat.AuthenticationCallback {
- @Override
- public void onAuthenticationError(int errMsgId, CharSequence errString) {
- //當出現錯誤的時候回調此函數,比如多次嘗試都失敗了的時候,errString是錯誤信息
- //一般來說我們都是先判斷一下是不是自己手動取消
- Log.e("TAG", "errMsgId=" + errMsgId);
- if (errMsgId == FingerprintManager.FINGERPRINT_ERROR_LOCKOUT) {
- Log.e("TAG", "" + errString);
- }
- }
- //當指紋驗證失敗的時候會回調此函數,失敗之后允許多次嘗試,失敗次數過多會停止響應一段時間然后再停止sensor的工作
- @Override
- public void onAuthenticationFailed() {
- //指紋認證失敗,請再試一次
- Log.e("TAG", "onAuthenticationFailed");
- }
- @Override
- public void onAuthenticationHelp(int helpMsgId, CharSequence helpString) {
- //錯誤時提示幫助,比如說指紋錯誤,我們將顯示在界面上 讓用戶知道情況
- Log.e("TAG", "helpString=" + helpString);
- }
- //當驗證的指紋成功時會回調此函數,然后不再監聽指紋sensor
- @Override
- public void onAuthenticationSucceeded(FingerprintManagerCompat.AuthenticationResult result) {
- //這里我們可以做取消彈框之類的
- Log.e("TAG", "onAuthenticationSucceeded=" + result.toString());
- }
- }
到此指紋驗證登錄流程完了,是不是很簡單;
總結
指紋這塊還有很多很多東西等著我們去學習,比如加密等;
一起學習加油;