您好,登錄后才能下訂單哦!
什么是指紋解鎖技術
根據人的指紋來驗證是否能夠解鎖的技術,類似于通過輸入密碼來解鎖,都是通過一定的數字特征來解鎖。
指紋解鎖技術原理理解
首先說明每個人的每個指紋信息都是獨一無二的,皮膚紋路在圖案,斷點,交叉點上各不相同,通過光學感應讀出指紋的圖片信息也是獨一無二的。
先保存一個人的指紋特征(圖片信息根據算法生成的數據),然后再使用時利用這個人的這個指紋特征去和先前保存的指紋特征做對比,對比一致則解鎖成功,對比不一致則解鎖失敗,對比結果并不是100%一樣,而可以按照一個比例來判定,比如90%一樣,也可以判定為一致,這個可以根據硬件來設定。
指紋解鎖技術的優勢和缺點
優點:1.使用便捷,直接使用自身的生物特征就可判斷能否使用,判別速度快,而輸入數字或者拼圖解鎖是麻煩的并且容易被別人看到。
缺點:1.安全性不高,指紋是可以被收集的,所以一旦別人收集了你的指紋信息,那需要你指紋解鎖的東西將非常危險,而且在不注意的情況下很容易被有心的人收集。
在Android中的應用開發
對Android系統來說,指紋解鎖是Android6.0才添加的新功能,到Android P系統還會強化指紋解鎖的功能,提供越來越便捷的API。
android.hardware.fingerprint
可以看到在Android P系統中FingerprintDialog以及其中的包含類將會替代FingerprintManager以及其中包含類。原理應該差不多,封裝的更簡潔易用。
廢話少說,在Android手機中如何開發?
1.在應用AndroidManifest.xml文件中添加權限:
<uses-permission android:name="android.permission.USE_FINGERPRINT"/>
2.獲取到指紋管理對象的引用:
FingerprintManagerCompat fingerprint = FingerprintManagerCompat.from(this); //v4包下的API,包裝內部已經判斷Android系統版本是否大于6.0,這也是官方推薦的方式 FingerprintManager fingerprint2 = (FingerprintManager) getSystemService(Context.FINGERPRINT_SERVICE); //Android 6.0包下的API
其實指紋對象依次調用三個方法就夠了,
第一步
/** * Determine if fingerprint hardware is present and functional. * @return true if hardware is present and functional, false otherwise. */ fingerprint.isHardwareDetected(); // 判斷設備是否支持指紋解鎖
第二步
/** * Determine if there is at least one fingerprint enrolled. * @return true if at least one fingerprint is enrolled, false otherwise */ fingerprint.hasEnrolledFingerprints(); //判斷設備是否以保存過指紋信息,至少需要保存過一個
第三步
/** * @param crypto object associated with the call or null if none required. //不太理解,加密指紋特征還是什么,可以不加密置為null * @param flags optional flags; should be 0 //設置標記,暫時無用 * @param cancel an object that can be used to cancel authentication //取消驗證 * @param callback an object to receive authentication events //系統認證完成之后,回調該接口 * @param handler an optional handler for events //處理callback接口后,界面的處理,默認是主線程handler */ fingerprint.authenticate(crypto, flags,cancel,callback,handler) //驗證指紋 再來說明各個參數的實現 crypto = null; //可以置為null,愿意了解的人可以參考底部博客和源碼 flags = 0; cancel = new CancellationSignal(); callback = new FingerprintManagerCompat.AuthenticationCallback() { @Override public void onAuthenticationError(int errMsgId, CharSequence errString) { super.onAuthenticationError(errMsgId, errString); //驗證錯誤時,回調該方法。當連續驗證5次錯誤時,將會走onAuthenticationFailed()方法 handler.obtainMessage(1,errMsgId,0).sendToTarget(); } @Override public void onAuthenticationSucceeded(FingerprintManagerCompat.AuthenticationResult result) { super.onAuthenticationSucceeded(result); //驗證成功時,回調該方法。fingerprint對象不能再驗證 handler.obtainMessage(2).sendToTarget(); } @Override public void onAuthenticationFailed() { super.onAuthenticationFailed(); //驗證失敗時,回調該方法。fingerprint對象不能再驗證并且需要等待一段時間才能重新創建指紋管理對象進行驗證 handler.obtainMessage(3).sendToTarget(); } }; handler = new Handler(getMainLooper()) { //也可以置為null,系統自動處理 @Override public void handleMessage(Message msg) { switch (msg.what) { case 1: //驗證錯誤 //todo 界面處理 handleErrorCode(msg.arg1); break; case 2: //驗證成功 //todo 界面處理 cancel = null; break; case 3: //驗證失敗 //todo 界面處理 cancel = null; break; default: super.handleMessage(msg); } }; //對應不同的錯誤,可以有不同的操作 private void handleErrorCode(int code) { switch (code) { case FingerprintManager.FINGERPRINT_ERROR_CANCELED: //todo 指紋傳感器不可用,該操作被取消 break; case FingerprintManager.FINGERPRINT_ERROR_HW_UNAVAILABLE: //todo 當前設備不可用,請稍后再試 break; case FingerprintManager.FINGERPRINT_ERROR_LOCKOUT: //todo 由于太多次嘗試失敗導致被鎖,該操作被取消 break; case FingerprintManager.FINGERPRINT_ERROR_NO_SPACE: //todo 沒有足夠的存儲空間保存這次操作,該操作不能完成 break; case FingerprintManager.FINGERPRINT_ERROR_TIMEOUT: //todo 操作時間太長,一般為30秒 break; case FingerprintManager.FINGERPRINT_ERROR_UNABLE_TO_PROCESS: //todo 傳感器不能處理當前指紋圖片 break; } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。