程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 更多關於編程 >> swift3.0指紋解鎖的實現方法

swift3.0指紋解鎖的實現方法

編輯:更多關於編程

swift3.0指紋解鎖的實現方法。本站提示廣大學習愛好者:(swift3.0指紋解鎖的實現方法)文章只能為提供參考,不一定能成為您想要的結果。以下是swift3.0指紋解鎖的實現方法正文


最近學習swift3.0, 不忙的時候開始用 Swift 重寫現有的項目,有些地方的寫法變得讓人不知道怎麼寫了,今天就分享一下我在重寫 指紋解鎖工具類的時候遇到的一些問題吧。

先展示一下成果

class ViewController: UIViewController {

  override func viewDidLoad() {
    super.viewDidLoad()

    TouchIdManager.touchIdWithHand(fallBackTitle: "", succeed: { 
      print("解鎖成功")
    }) { (error) in
      print(error.localizedDescription) 
    }

    print(TouchIdManager.IsSupportTouchID)

  }
}

import LocalAuthentication
class TouchIdManager {

  /// 指紋解鎖
  ///
  /// - Parameters:
  ///  - fallBackTitle: Allows fallback button title customization. A default title "Enter Password" is used when
  ///       this property is left nil. If set to empty string, the button will be hidden
  ///  - succeed: 解鎖成功的回調
  ///  - failed: 解鎖失敗的回調
  class func touchIdWithHand(fallBackTitle: String?, succeed: @escaping () -> (), failed: @escaping (_ error: LAError) -> ()) {

    guard self.IsSupportTouchID else {
      print("設備不支持TouchID 或未開啟TouchID ")
      return
    }

    let context = LAContext()
    context.localizedFallbackTitle = fallBackTitle
    let reason = "驗證指紋,完成支付"
    context.evaluatePolicy(LAPolicy.deviceOwnerAuthenticationWithBiometrics, localizedReason: reason, reply: { (isSuccess, err) in

      OperationQueue.main.addOperation({

        guard isSuccess == true, err == nil else {
          let laerror = err as! LAError
          failed(laerror)
//          switch laerror.code {
//          case LAError.authenticationFailed: 
//            print("連續三次輸入錯誤,身份驗證失敗。")
//          case LAError.userCancel: 
//            print("用戶點擊取消按鈕。")
//          case LAError.userFallback: 
//            print("用戶點擊輸入密碼。")
//          case LAError.systemCancel: 
//            print("系統取消")
//          case LAError.passcodeNotSet: 
//            print("用戶未設置密碼")
//          case LAError.touchIDNotAvailable: 
//            print("touchID不可用")
//          case LAError.touchIDNotEnrolled: 
//            print("touchID未設置指紋")
//          default: break
//          }

          return
        }
        succeed()
      })
    })
  }

  /// 檢查手機 TouchID 功能是否開啟或可以使用
  class var IsSupportTouchID: Bool {
    get {
      let context = LAContext()
      var error :NSError?
      let isSupport = context.canEvaluatePolicy(LAPolicy.deviceOwnerAuthenticationWithBiometrics, error: &error)
      return isSupport
    }
  }  
}

在實現的時候主要遇到的問題是, 對 evaluatePolicy 方法中回調的 Error 值的處理;
方法定義:
func evaluatePolicy(_ policy: LAPolicy, localizedReason: String, reply: @escaping (Bool, Error?) -> Swift.Void)

由於swift對參數類型嚴格校驗,而 Error 是一個協議,它並沒有 Error.code 的值來跟各種錯誤類型來對應;
swift 2 中,我在這一塊是這麼寫的

switch LAError(rawValue: error!.code) {

          case .Some(LAError.AuthenticationFailed):
            print("連續三次輸入錯誤,身份驗證失敗。")
          case .Some(LAError.UserCancel):
            print("用戶點擊取消按鈕。")
          case .Some(LAError.UserFallback):
            print("用戶點擊輸入密碼。")
          case .Some(LAError.SystemCancel):
            print("系統取消")
          case .Some(LAError.PasscodeNotSet):
            print("用戶未設置密碼")
          case .Some(LAError.TouchIDNotAvailable):
            print("touchID不可用")
          case .Some(LAError.TouchIDNotEnrolled):
            print("touchID未設置指紋")
          default:
            break
          }

swift3 中取消了這種語法, 但是處理起來更簡單了,可以將 Error 直接強轉成 LAError 就行了

let laerror = err as! LAError

但是,有個疑問,我要怎麼才能最快的知道 需要強轉成什麼類型呢? 有知道的 謝謝告知!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved