淺析IOS開(kāi)發(fā)TouchID指紋解鎖功能
效果圖如下
實(shí)現(xiàn)過(guò)程
1.首先引入指紋解鎖必須的頭文件
#import <LocalAuthentication/LocalAuthentication.h>
2.了解下主要的兩個(gè)方法
這個(gè)方法是判斷設(shè)備是否支持TouchID的。
- (BOOL)canEvaluatePolicy:(LAPolicy)policy error:(NSError * __autoreleasing *)error __attribute__((swift_error(none)));
這個(gè)是用來(lái)驗(yàn)證TouchID的,會(huì)有彈出框出來(lái)。
- (void)evaluatePolicy:(LAPolicy)policy localizedReason:(NSString *)localizedReason reply:(void(^)(BOOL success, NSError * __nullable error))reply;
3.新建LAContext對(duì)象
主要的屬性設(shè)置
localizedFallbackTitle
:用于設(shè)置左邊的按鈕的名稱,默認(rèn)是Enter Password.
localizedReason
:用于設(shè)置提示語(yǔ),表示為什么要使用Touch ID
解鎖失敗界面
//創(chuàng)建LAContext LAContext *context = [LAContext new]; //這個(gè)屬性是設(shè)置指紋輸入失敗之后的彈出框的選項(xiàng) context.localizedFallbackTitle = @"沒(méi)有忘記密碼";
4.主要回調(diào)方法,包括成功以及失敗的
NSError *error = nil; if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) { NSLog(@"支持指紋識(shí)別"); [context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"指紋解鎖" reply:^(BOOL success, NSError * _Nullable error) { if (success) { NSLog(@"驗(yàn)證成功 刷新主界面"); }else{ NSLog(@"%@",error.localizedDescription); switch (error.code) { case LAErrorSystemCancel: { NSLog(@"系統(tǒng)取消授權(quán),如其他APP切入"); break; } case LAErrorUserCancel: { NSLog(@"用戶取消驗(yàn)證Touch ID"); break; } case LAErrorAuthenticationFailed: { NSLog(@"授權(quán)失敗"); break; } case LAErrorPasscodeNotSet: { NSLog(@"系統(tǒng)未設(shè)置密碼"); break; } case LAErrorTouchIDNotAvailable: { NSLog(@"設(shè)備Touch ID不可用,例如未打開(kāi)"); break; } case LAErrorTouchIDNotEnrolled: { NSLog(@"設(shè)備Touch ID不可用,用戶未錄入"); break; } case LAErrorUserFallback: { [[NSOperationQueue mainQueue] addOperationWithBlock:^{ NSLog(@"用戶選擇輸入密碼,切換主線程處理"); }]; break; } default: { [[NSOperationQueue mainQueue] addOperationWithBlock:^{ NSLog(@"其他情況,切換主線程處理"); }]; break; } } } }]; }else{ NSLog(@"不支持指紋識(shí)別"); switch (error.code) { case LAErrorTouchIDNotEnrolled: { NSLog(@"TouchID is not enrolled"); break; } case LAErrorPasscodeNotSet: { NSLog(@"A passcode has not been set"); break; } default: { NSLog(@"TouchID not available"); break; } } NSLog(@"%@",error.localizedDescription); }
總結(jié)
到這里指紋解鎖功能幾乎就算完成,使用確實(shí)很簡(jiǎn)單,因?yàn)樘O果都已經(jīng)給我們做好一切,對(duì)我們開(kāi)發(fā)者來(lái)說(shuō)就很輕松了。教程寫的很簡(jiǎn)陋,希望大家多多包涵,如果有疑問(wèn)大家可以留言交流。
- iOS 指紋解鎖驗(yàn)證TouchID功能
- 簡(jiǎn)單實(shí)現(xiàn)iOS指紋解鎖(TouchID)
- iOS指紋驗(yàn)證TouchID應(yīng)用學(xué)習(xí)教程2
- iOS指紋驗(yàn)證TouchID應(yīng)用學(xué)習(xí)教程
- IOS 指紋識(shí)別詳解及實(shí)例代碼
- iOS中指紋識(shí)別常見(jiàn)問(wèn)題匯總
- 使用Swift代碼實(shí)現(xiàn)iOS手勢(shì)解鎖、指紋解鎖實(shí)例詳解
- iOS中應(yīng)用內(nèi)添加指紋識(shí)別的實(shí)例代碼
- IOS 指紋識(shí)別兩種方式詳解及實(shí)例
- iOS指紋登錄(TouchID)集成方案詳解
相關(guān)文章
iOS判斷用戶是否打開(kāi)APP通知開(kāi)關(guān)
這篇文章主要為大家詳細(xì)介紹了iOS判斷用戶是否打開(kāi)APP通知開(kāi)關(guān)的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04詳解IOS 利用storyboard修改UITextField的placeholder文字顏色
這篇文章主要介紹了詳解IOS 利用storyboard修改UITextField的placeholder文字顏色的相關(guān)資料,希望通過(guò)本文能實(shí)現(xiàn)這樣類似的功能,需要的朋友可以參考下2017-08-08iOS UIWebView 通過(guò) cookie 完成自動(dòng)登錄實(shí)例
本篇文章主要介紹了iOS UIWebView 通過(guò) cookie 完成自動(dòng)登錄實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04簡(jiǎn)介Objective-C解析XML與JSON數(shù)據(jù)格式的方法
這篇文章主要介紹了Objective-C解析XML與JSON數(shù)據(jù)格式的方法,文中解析JSON包括拼接JSON字符串用到了SBJson這個(gè)解析器,需要的朋友可以參考下2016-01-01iOS開(kāi)發(fā)之tableView cell的展開(kāi)收回功能實(shí)現(xiàn)代碼
本文介紹了iOS開(kāi)發(fā)之tableView cell的展開(kāi)收回功能實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果
這篇文章主要為大家詳細(xì)介紹了iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05IOS等待時(shí)動(dòng)畫(huà)效果的實(shí)現(xiàn)
查詢時(shí)間有長(zhǎng)有短,為了增強(qiáng)用戶體驗(yàn)度,目前用的比較多的手段之一是查詢等待時(shí)添加一個(gè)動(dòng)態(tài)等待效果,這篇文章主要介紹IOS等待時(shí)動(dòng)畫(huà)效果的實(shí)現(xiàn),有需要的朋友可以參考下2015-08-08