溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

iOS指紋登錄(TouchID)集成方案詳解

發(fā)布時(shí)間:2020-10-11 01:39:04 來源:腳本之家 閱讀:274 作者:軟件iOS開發(fā) 欄目:移動(dòng)開發(fā)

TouchID指紋識(shí)別是iPhone 5S設(shè)備中增加的一項(xiàng)重大功能.蘋果的后續(xù)移動(dòng)設(shè)備也相繼添加了指紋功能,在實(shí)際使用中還是相當(dāng)方便的,比如快捷登錄,快捷支付等等.系統(tǒng)提供了相應(yīng)框架,使用起來還是比較方便的.使用LAContext對(duì)象即可完成指紋識(shí)別,提高用戶體驗(yàn).

iOS指紋登錄(TouchID)集成方案詳解

提示:指紋識(shí)別必須用真機(jī)測試,并且在iOS8以上系統(tǒng).

TouchID API使用

1.添加頭文件

#import

2.判斷系統(tǒng)版本

 //首先判斷版本
if (NSFoundationVersionNumber < NSFoundationVersionNumber_iOS_8_0) {
  NSLog(@"系統(tǒng)版本不支持TouchID");
  return;
}

3.LAPolicy

在這里簡單介紹一下LAPolicy,它是一個(gè)枚舉.我們根據(jù)自己的需要選擇LAPolicy,它提供兩個(gè)值:

LAPolicyDeviceOwnerAuthenticationWithBiometrics和LAPolicyDeviceOwnerAuthentication.

<1>. LAPolicyDeviceOwnerAuthenticationWithBiometrics是支持iOS8以上系統(tǒng),使用該設(shè)備的TouchID進(jìn)行驗(yàn)證,當(dāng)輸入TouchID驗(yàn)證5次失敗后,TouchID被鎖定,只能通過鎖屏后解鎖設(shè)備時(shí)輸入正確的解鎖密碼來解鎖TouchID。

<2>.LAPolicyDeviceOwnerAuthentication是支持iOS9以上系統(tǒng),使用該設(shè)備的TouchID或設(shè)備密碼進(jìn)行驗(yàn)證,當(dāng)輸入TouchID驗(yàn)證5次失敗后,TouchID被鎖定,會(huì)觸發(fā)設(shè)備密碼頁面進(jìn)行驗(yàn)證。

4. canEvaluatePolicy

使用canEvaluatePolicy方法判斷設(shè)備是否支持TouchID,返回BOOL為YES,該設(shè)備支持TouchID。

 if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) {

error為返回驗(yàn)證錯(cuò)誤碼.具體不解釋了.

5. evaluatedPolicyDomainState

context.evaluatedPolicyDomainState用于判斷設(shè)備上的指紋是否被更改,在LAContext被創(chuàng)建的時(shí)候,evaluatedPolicyDomainState才生效,可在TouchID驗(yàn)證成功時(shí),將它記錄下來,用于下次使用TouchID時(shí)校驗(yàn),提高安全性。

6. evaluatePolicy

evaluatePolicy方法是對(duì)TouchID進(jìn)行驗(yàn)證,Block回調(diào)中如果success為YES則驗(yàn)證成功,為NO驗(yàn)證失敗,并對(duì)error進(jìn)行解析.

- (IBAction)loginButtonClick:(UIButton *)sender {
  
 //首先判斷版本
 if (NSFoundationVersionNumber < NSFoundationVersionNumber_iOS_8_0) {
  NSLog(@"系統(tǒng)版本不支持TouchID");
  return;
 }
  
  
 LAContext *context = [[LAContext alloc] init];
 context.localizedFallbackTitle = @"輸入密碼";
 if (@available(iOS 10.0, *)) {
//  context.localizedCancelTitle = @"22222";
 } else {
  // Fallback on earlier versions
 }
 NSError *error = nil;
 
 if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) {
   
  [context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"通過Home鍵驗(yàn)證已有手機(jī)指紋" reply:^(BOOL success, NSError * _Nullable error) {
    
   if (success) {
    dispatch_async(dispatch_get_main_queue(), ^{
     NSLog(@"TouchID 驗(yàn)證成功");
    });
   }else if(error){
     
    switch (error.code) {
     case LAErrorAuthenticationFailed:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 驗(yàn)證失敗");
      });
      break;
     }
     case LAErrorUserCancel:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 被用戶手動(dòng)取消");
      });
     }
      break;
     case LAErrorUserFallback:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"用戶不使用TouchID,選擇手動(dòng)輸入密碼");
      });
     }
      break;
     case LAErrorSystemCancel:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 被系統(tǒng)取消 (如遇到來電,鎖屏,按了Home鍵等)");
      });
     }
      break;
     case LAErrorPasscodeNotSet:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 無法啟動(dòng),因?yàn)橛脩魶]有設(shè)置密碼");
      });
     }
      break;
     case LAErrorTouchIDNotEnrolled:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 無法啟動(dòng),因?yàn)橛脩魶]有設(shè)置TouchID");
      });
     }
      break;
     case LAErrorTouchIDNotAvailable:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 無效");
      });
     }
      break;
     case LAErrorTouchIDLockout:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"TouchID 被鎖定(連續(xù)多次驗(yàn)證TouchID失敗,系統(tǒng)需要用戶手動(dòng)輸入密碼)");
      });
     }
      break;
     case LAErrorAppCancel:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"當(dāng)前軟件被掛起并取消了授權(quán) (如App進(jìn)入了后臺(tái)等)");
      });
     }
      break;
     case LAErrorInvalidContext:{
      dispatch_async(dispatch_get_main_queue(), ^{
       NSLog(@"當(dāng)前軟件被掛起并取消了授權(quán) (LAContext對(duì)象無效)");
      });
     }
      break;
     default:
      break;
    }
   }
  }];
   
 }else{
  NSLog(@"當(dāng)前設(shè)備不支持TouchID");
 }
}

上面這個(gè)代碼, 是整個(gè)TouchID的核心,也幾乎是所有代碼了.

驗(yàn)證

驗(yàn)證必須使用真機(jī)

iOS指紋登錄(TouchID)集成方案詳解

結(jié)果

iOS指紋登錄(TouchID)集成方案詳解

輸入錯(cuò)誤的時(shí)候

總結(jié):TouchID使用起來不難,重要的是使用流程邏輯.

以登錄為例,一般來說流程是這樣的:

  • 開啟指紋登錄:首次登陸使用密碼登錄,登錄后,可以設(shè)置一個(gè)開啟指紋ID登錄的按鈕,來進(jìn)行指紋認(rèn)證.
  • 驗(yàn)證:檢測是否支持TouchID.
  • 生成設(shè)備賬號(hào)/密碼:TouchID驗(yàn)證通過后,根據(jù)當(dāng)前已登錄的賬號(hào)和硬件設(shè)備Token,生成設(shè)備賬號(hào)/密碼(規(guī)則可自定,密碼要長要復(fù)雜),并保存在keychain;
  • 綁定:生成設(shè)備賬號(hào)/密碼后,將原賬號(hào)及設(shè)備賬號(hào)/密碼,加密后(題主使用的是RSA加密)發(fā)送到服務(wù)端進(jìn)行綁定;
  • 成功:驗(yàn)證原賬號(hào)及設(shè)備賬號(hào)有效后,返回相應(yīng)狀態(tài),綁定成功則完成整個(gè)TouchID(設(shè)備)綁定流程。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI