Android指紋識別API初試
在android6.0之后谷歌對指紋識別進行了官方支持,今天還在放假,所以就隨意嘗試了一下這個api,但是遇到了各種各樣的問題
①在使用FingerPrintManager這個類實現的時候發(fā)現了很多問題,這個類里面的一些函數是被hide了的,也就是我們不能調用,比如enroll(),也就是說,當前的官方支持其實是有限的,我們能讀取到本機已經存在的指紋(用于解鎖的),然后驗證這些指紋,但是不能讓用戶在app使用的時候錄入一個指紋,用于app的其他功能,這個是一個缺陷吧目前來說,下面的圖也是展示了識別一個可以用來解鎖的指紋的功能。
②使用FingerPrintManager的時候會遇到要在應用中判斷權限的問題,不清楚是因為android M要求的還是api需要,調用的時候也沒有反應,既沒有功能,也沒有提示給予權限,原因有待查證。
③在一頓嘗試無果之后發(fā)現了兩個特別的類,一個叫做FingerPrintManagerCompat,這是一個兼容的FingerPrint操作類,還有一個類似的叫做FingerPrintManagerCompatApi23,使用這兩個類也能實現到識別指紋的功能,但是也是有局限的,如①所說的。這兩個類都能實現這個效果,但是需要API Level 23,如果達不到不會報錯,這些類會什么都不做。
展示圖,因為沒有真機,所以只能用模擬器調試一下,這里也只能用官方的,Genymotion免費版貌似不能模擬指紋:

直接上代碼:
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private static final String TAG = "MainActivity";
private Button check;
private FingerprintManagerCompat manager;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
check = (Button) findViewById(R.id.btn_check);
check.setOnClickListener(this);
// 獲取一個FingerPrintManagerCompat的實例
manager = FingerprintManagerCompat.from(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.btn_check:
/**
* 開始驗證,什么時候停止由系統(tǒng)來確定,如果驗證成功,那么系統(tǒng)會關系sensor,如果失敗,則允許
* 多次嘗試,如果依舊失敗,則會拒絕一段時間,然后關閉sensor,過一段時候之后再重新允許嘗試
*
* 第四個參數為重點,需要傳入一個FingerprintManagerCompat.AuthenticationCallback的子類
* 并重寫一些方法,不同的情況回調不同的函數
*/
manager.authenticate(null, 0, null, new MyCallBack(), null);
break;
}
}
public class MyCallBack extends FingerprintManagerCompat.AuthenticationCallback {
private static final String TAG = "MyCallBack";
// 當出現錯誤的時候回調此函數,比如多次嘗試都失敗了的時候,errString是錯誤信息
@Override
public void onAuthenticationError(int errMsgId, CharSequence errString) {
Log.d(TAG, "onAuthenticationError: " + errString);
}
// 當指紋驗證失敗的時候會回調此函數,失敗之后允許多次嘗試,失敗次數過多會停止響應一段時間然后再停止sensor的工作
@Override
public void onAuthenticationFailed() {
Log.d(TAG, "onAuthenticationFailed: " + "驗證失敗");
}
@Override
public void onAuthenticationHelp(int helpMsgId, CharSequence helpString) {
Log.d(TAG, "onAuthenticationHelp: " + helpString);
}
// 當驗證的指紋成功時會回調此函數,然后不再監(jiān)聽指紋sensor
@Override
public void onAuthenticationSucceeded(FingerprintManagerCompat.AuthenticationResult
result) {
Log.d(TAG, "onAuthenticationSucceeded: " + "驗證成功");
}
}
}
有朋友提出了問題,這里記錄下:
如何讓失敗或者成功之后Sensor繼續(xù)保持監(jiān)聽新的指紋?
答:因為API較新的緣故,這個兼容的Manager類還不能做到自動重啟的功能,但是我們可以自己寫一個。因為Api中規(guī)定了如果回調了Error或者Succeed方法之后,sensor會被關閉,直到下一次重新調用authenticate方法授權,但是我們不能在Error或Succeed直接調用這個方法,因為處于安全性的考慮,不允許開發(fā)者短時間內連續(xù)授權,經過粗略的測試,android允許我們在30s之后重新打開Sensor授權監(jiān)聽,所以我們要做的,就是通過Handler的sendMessageDelayed方法發(fā)送一個延遲的消息,再在Handler中重新調用authenticate方法,具體的代碼如下:
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
Log.d(TAG, "handleMessage: 重啟指紋模塊");
manager.authenticate(null, 0, null, new MyCallBack(), handler);
}
};
@Override
public void onAuthenticationError(int errMsgId, CharSequence errString) {
handler.sendMessageDelayed(new Message(), 1000 * 30);
Log.d(TAG, "onAuthenticationError: " + errString);
}
@Override
public void onAuthenticationSucceeded(FingerprintManagerCompat.AuthenticationResult result) {
handler.sendMessageDelayed(new Message(), 1000 * 30);
Log.d(TAG, "onAuthenticationSucceeded: " + "驗證成功");
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
詳解android特性之CoordinatorLayout用法探析實例
本篇文章主要介紹了android特性之CoordinatorLayout用法探析實例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-02
NestScrollView嵌套RecyclerView實現淘寶首頁滑動效果
這篇文章主要介紹了NestScrollView嵌套RecyclerView實現淘寶首頁滑動效果,主要實現淘寶首頁嵌套滑動,中間tab吸頂效果,以及介紹NestScrollView嵌套RecyclerView處理滑動沖突的方法,需要的朋友可以參考下2021-12-12
Android開發(fā)實現的獲取sdcard大小及內存大小工具類
這篇文章主要介紹了Android開發(fā)實現的獲取sdcard大小及內存大小工具類,涉及Android針對手機硬件SD卡及內存相關操作技巧,需要的朋友可以參考下2017-11-11
Android SharePreferences與數據庫SQLite存儲實現方法介紹
這篇文章主要介紹了Android SharePreferences與數據庫SQLite用于存儲的具體實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2022-09-09

