Android指紋解鎖方法解析
我先說說這兩種的方式的不同之處吧
第一種:
在調(diào)動(dòng)成功之后 不會(huì)讓你指紋解鎖 而是調(diào)轉(zhuǎn)到當(dāng)初你設(shè)置指紋解鎖時(shí)的 手勢(shì)解鎖頁面
第二種:
在調(diào)動(dòng)成功之后,是進(jìn)行指紋解鎖 不調(diào)轉(zhuǎn) 你直接把手指放到金屬感應(yīng)環(huán) 上面進(jìn)行指紋驗(yàn)證
大家可以根據(jù)需求 自行選擇
ok 那就亮代碼了
第一種:
xml 布局: 一個(gè) 文本顯示 一個(gè)按鈕(不解釋)
MainActivity.java源碼
public class MainActivity extends FragmentActivity { FingerprintManager manager; KeyguardManager mKeyManager; private final static int REQUEST_CODE_CONFIRM_DEVICE_CREDENTIALS = 0; private final static String TAG = “finger_log”; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //1:先獲取 指紋識(shí)別的的管理者 看看獲取方式 是不是感覺就和數(shù)學(xué)公式一樣 (xxx管理者)=this.getSystemService(Context.xxx服務(wù)) manager = (FingerprintManager) this.getSystemService(Context.FINGERPRINT_SERVICE); mKeyManager = (KeyguardManager) this.getSystemService(Context.KEYGUARD_SERVICE); // 2 初始化按鈕 設(shè)置監(jiān)聽 // 監(jiān)聽 監(jiān)聽 聽什么 肯定是聽聽 這個(gè)手機(jī)有沒有 指紋識(shí)別這個(gè)功能 所以 看看isFinger() Button btn_finger = (Button) findViewById(R.id.btn_activity_main_finger); btn_finger.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (isFinger()) { Toast.makeText(MainActivity.this, "請(qǐng)進(jìn)行指紋識(shí)別", Toast.LENGTH_LONG).show(); Log(TAG, "keyi"); startListening(null); } } }); } public boolean isFinger() { //android studio 上,沒有這個(gè)會(huì)報(bào)錯(cuò) if (ActivityCompat.checkSelfPermission(this, Manifest.permission.USE_FINGERPRINT) != PackageManager.PERMISSION_GRANTED) { Toast.makeText(this, "沒有指紋識(shí)別權(quán)限", Toast.LENGTH_SHORT).show(); return false; } Log(TAG, "有指紋權(quán)限"); //判斷硬件是否支持指紋識(shí)別 if (!manager.isHardwareDetected()) { Toast.makeText(this, "沒有指紋識(shí)別模塊", Toast.LENGTH_SHORT).show(); return false; } Log(TAG, "有指紋模塊"); //判斷 是否開啟鎖屏密碼 if (!mKeyManager.isKeyguardSecure()) { Toast.makeText(this, "沒有開啟鎖屏密碼", Toast.LENGTH_SHORT).show(); return false; } Log(TAG, "已開啟鎖屏密碼"); //判斷是否有指紋錄入 if (!manager.hasEnrolledFingerprints()) { Toast.makeText(this, "沒有錄入指紋", Toast.LENGTH_SHORT).show(); return false; } Log(TAG, "已錄入指紋"); return true; } CancellationSignal mCancellationSignal = new CancellationSignal(); //回調(diào)方法 FingerprintManager.AuthenticationCallback mSelfCancelled = new FingerprintManager.AuthenticationCallback() { @Override public void onAuthenticationError(int errorCode, CharSequence errString) { //但多次指紋密碼驗(yàn)證錯(cuò)誤后,進(jìn)入此方法;并且,不能短時(shí)間內(nèi)調(diào)用指紋驗(yàn)證 Toast.makeText(MainActivity.this, errString, Toast.LENGTH_SHORT).show(); showAuthenticationScreen(); } @Override public void onAuthenticationHelp(int helpCode, CharSequence helpString) { Toast.makeText(MainActivity.this, helpString, Toast.LENGTH_SHORT).show(); } @Override public void onAuthenticationSucceeded(FingerprintManager.AuthenticationResult result) { Toast.makeText(MainActivity.this, "指紋識(shí)別成功", Toast.LENGTH_SHORT).show(); } @Override public void onAuthenticationFailed() { Toast.makeText(MainActivity.this, "指紋識(shí)別失敗", Toast.LENGTH_SHORT).show(); } }; public void startListening(FingerprintManager.CryptoObject cryptoObject) { //android studio 上,沒有這個(gè)會(huì)報(bào)錯(cuò) if (ActivityCompat.checkSelfPermission(this, Manifest.permission.USE_FINGERPRINT) != PackageManager.PERMISSION_GRANTED) { Toast.makeText(this, "沒有指紋識(shí)別權(quán)限", Toast.LENGTH_SHORT).show(); return; } manager.authenticate(cryptoObject, mCancellationSignal, 0, mSelfCancelled, null); } /** * 鎖屏密碼 */ private void showAuthenticationScreen() { Intent intent = mKeyManager.createConfirmDeviceCredentialIntent("finger", "測(cè)試指紋識(shí)別"); if (intent != null) { startActivityForResult(intent, REQUEST_CODE_CONFIRM_DEVICE_CREDENTIALS); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_CODE_CONFIRM_DEVICE_CREDENTIALS) { // Challenge completed, proceed with using cipher if (resultCode == RESULT_OK) { Toast.makeText(this, "識(shí)別成功", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(this, "識(shí)別失敗", Toast.LENGTH_SHORT).show(); } } } private void Log(String tag, String msg) { Log.d(tag, msg); } }
===================================
第二種:
1:xml: 布局 一個(gè)文本提示 兩個(gè)按鈕(1: 開始識(shí)別 2:取消識(shí)別)
2: 咱們將業(yè)務(wù)操作放到一個(gè)FingerprintController 類里面
private static FingerprintController sSingleton = null; private Context mContext; private FingerprintManagerCompat manager; private static final String TAG = "FingerprintController"; private static final String PREMISSION = "android.permission.USE_FINGERPRINT"; //成功 public static final int FINGER_SUCCESS = 0; //硬件不支持 public static final int FINGER_ERROR_NO_HARDWARE = 1; //沒有申請(qǐng)權(quán)限 public static final int FINGER_ERROR_NO_PERMISSION = 2; //用戶沒有賦予權(quán)限 //Protection level: normal //指紋權(quán)限的級(jí)別是normal,理論上不需要?jiǎng)討B(tài)權(quán)限認(rèn)證 public static final int FINGER_ERROR_NO_USER_PERMISSION = 3; //用戶沒有儲(chǔ)存指紋 public static final int FINGER_ERROR_NO_FINGER = 4; //取消指紋識(shí)別 private CancellationSignal cancellationSignal; private FingerAuthListener mAuthListener; public static synchronized FingerprintController getInstance(Context context) { if (sSingleton == null) { sSingleton = new FingerprintController(context); } return sSingleton; } public FingerprintController(Context context) { mContext = context; manager = FingerprintManagerCompat.from(this.mContext); } /** * 開始指紋識(shí)別 * 失敗次數(shù)過多后需要一定時(shí)間后才可以重新啟動(dòng) */ public void startFingerAuth() { if (null == cancellationSignal) { cancellationSignal = new CancellationSignal(); } manager.authenticate(null, 0, cancellationSignal, new FingerAuthCallBack(), null); } /** * 取消指紋識(shí)別 */ public void cancelFingerAuth() { if (cancellationSignal != null) { cancellationSignal.cancel(); if (mAuthListener != null) mAuthListener.cancel(); } } /** * 指紋識(shí)別回調(diào) */ public class FingerAuthCallBack extends FingerprintManagerCompat.AuthenticationCallback { // 當(dāng)出現(xiàn)錯(cuò)誤的時(shí)候回調(diào)此函數(shù),比如多次嘗試都失敗了的時(shí)候,errString是錯(cuò)誤信息 @Override public void onAuthenticationError(int errMsgId, CharSequence errString) { // Log.d(TAG, “onAuthenticationError: ” + errString); if (null != mAuthListener) mAuthListener.error(errString.toString()); } // 當(dāng)指紋驗(yàn)證失敗的時(shí)候會(huì)回調(diào)此函數(shù),失敗之后允許多次嘗試,失敗次數(shù)過多會(huì)停止響應(yīng)一段時(shí)間然后再停止sensor的工作 @Override public void onAuthenticationFailed() { if (null != mAuthListener) mAuthListener.failure(); } @Override public void onAuthenticationHelp(int helpMsgId, CharSequence helpString) { if (null != mAuthListener) Log.e("helpMsgId",helpMsgId+""); Log.e("helpString",helpString.toString()); mAuthListener.help(helpString.toString()); } // 當(dāng)驗(yàn)證的指紋成功時(shí)會(huì)回調(diào)此函數(shù),然后不再監(jiān)聽指紋sensor @Override public void onAuthenticationSucceeded(FingerprintManagerCompat.AuthenticationResult result) { if (null != mAuthListener) mAuthListener.success(); } } /** * 檢查指紋解鎖是否可用 * * @return 狀態(tài) */ public int checkFingerEnable() { if (null == manager) { manager = FingerprintManagerCompat.from(mContext); } if (!isAppPermissionEnable()) { return FINGER_ERROR_NO_PERMISSION; } if (!manager.isHardwareDetected()) { return FINGER_ERROR_NO_HARDWARE; } if (!manager.hasEnrolledFingerprints()) { return FINGER_ERROR_NO_FINGER; } if (!isUserPermissionEnable()) { return FINGER_ERROR_NO_USER_PERMISSION; } return FINGER_SUCCESS; } /** * 是否聲明了該權(quán)限 */ private boolean isAppPermissionEnable() { PackageManager pm = mContext.getPackageManager(); if (pm == null) { Log.w(TAG, "can't get packagemanager"); return true; } try { return PackageManager.PERMISSION_GRANTED == pm.checkPermission(PREMISSION, mContext.getPackageName()); } catch (Exception e) { Log.w(TAG, "can't checkt Permission " + e.getMessage()); return true; } } /** * 是否具有動(dòng)態(tài)權(quán)限,理論上不需要驗(yàn)證 */ private boolean isUserPermissionEnable() { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) { return PackageManager.PERMISSION_GRANTED == mContext.checkSelfPermission(Manifest.permission.USE_FINGERPRINT); } return true; } public void setAuthListener(FingerAuthListener authListener) { mAuthListener = authListener; } public interface FingerAuthListener { void success(); void error(String error); void help(String msg); void cancel(); void failure(); } }
3:在 main中 實(shí)現(xiàn) FingerprintController.FingerAuthListener這個(gè) 回調(diào)接口
private int code = FingerprintController.FINGER_SUCCESS; private TextView toast; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); toast = (TextView) findViewById(R.id.toast); code = FingerprintController.getInstance(this).checkFingerEnable(); if (code == FingerprintController.FINGER_SUCCESS) { FingerprintController.getInstance(this).setAuthListener(this); setToast("可以啟動(dòng)指紋識(shí)別"); } else { switch (code) { case FingerprintController.FINGER_ERROR_NO_HARDWARE: setToast("該設(shè)備不支持指紋識(shí)別"); break; case FingerprintController.FINGER_ERROR_NO_PERMISSION: setToast("當(dāng)前應(yīng)用沒有指紋識(shí)別權(quán)限"); break; case FingerprintController.FINGER_ERROR_NO_FINGER: setToast("當(dāng)前設(shè)備沒有錄入指紋,請(qǐng)前往錄入指紋"); break; } } } public void start(View view) { if (code == FingerprintController.FINGER_SUCCESS) { FingerprintController.getInstance(this).startFingerAuth(); setToast("開始指紋識(shí)別"); } } public void cancel(View view) { if (code == FingerprintController.FINGER_SUCCESS) { FingerprintController.getInstance(this).cancelFingerAuth(); } } @Override public void success() { setToast("識(shí)別成功"); } @Override public void error(String error) { setToast(error); } @Override public void help(String msg) { setToast(msg); } @Override public void cancel() { setToast("取消指紋識(shí)別"); } @Override public void failure() { setToast("指紋識(shí)別失敗"); } public void setToast(String msg) { toast.setText("提示:" + msg); }
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android 自定義TextView實(shí)現(xiàn)滑動(dòng)解鎖高亮文字
- Android自定義滑動(dòng)解鎖控件使用詳解
- 使用Android自定義控件實(shí)現(xiàn)滑動(dòng)解鎖九宮格
- android滑動(dòng)解鎖震動(dòng)效果的開啟和取消
- android 九宮格滑動(dòng)解鎖開機(jī)實(shí)例源碼學(xué)習(xí)
- Android點(diǎn)亮屏幕或屏幕解鎖和鎖定以及其他相關(guān)權(quán)限實(shí)現(xiàn)代碼
- 輕松實(shí)現(xiàn)Android自定義九宮格圖案解鎖
- Android 監(jiān)聽鎖屏、解鎖、開屏 功能代碼
- Android實(shí)現(xiàn)九宮格解鎖
- Android模擬實(shí)現(xiàn)滑動(dòng)解鎖界面
相關(guān)文章
Android模擬器安裝APP出現(xiàn)INSTALL_FAILED_NO_MATCHING_ABIS錯(cuò)誤解決方案
這篇文章主要介紹了 Android模擬器安裝APP出現(xiàn)INSTALL_FAILED_NO_MATCHING_ABIS錯(cuò)誤解決方案的相關(guān)資料,需要的朋友可以參考下2016-12-12Flutter利用SizeTransition實(shí)現(xiàn)組件飛入效果
本文將為大家介紹SizeTransition,SizeTransition用于更改子組件的尺寸來實(shí)現(xiàn)動(dòng)畫,支持垂直方向或水平方向修改動(dòng)畫。本文將利用其實(shí)現(xiàn)組件飛入效果,需要的可以參考一下2022-04-04android通過servlet服務(wù)器保存文件到手機(jī)
這篇文章主要為大家詳細(xì)介紹了android通過servlet服務(wù)器保存文件到手機(jī),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06android實(shí)現(xiàn)注冊(cè)頁面開發(fā)
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)注冊(cè)頁面開發(fā),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04Android StepView實(shí)現(xiàn)物流進(jìn)度效果
這篇文章主要為大家詳細(xì)介紹了Android StepView實(shí)現(xiàn)物流進(jìn)度效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05直接應(yīng)用項(xiàng)目中的Android圖片緩存技術(shù)
這篇文章主要為大家詳細(xì)介紹了直接應(yīng)用項(xiàng)目中的Android圖片緩存技術(shù),簡單、方便、高效,感興趣的小伙伴們可以參考一下2016-04-04VS Code開發(fā)React-Native及Flutter 開啟無線局域網(wǎng)安卓真機(jī)調(diào)試問題
這篇文章主要介紹了VS Code開發(fā)React-Native,F(xiàn)lutter 開啟無線局域網(wǎng)安卓真機(jī)調(diào)試,需要的朋友可以參考下2020-04-04