swift3.0指纹解锁的实现方法

时间:2022-11-30

最近学习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

但是,有个疑问,我要怎么才能最快的知道 需要强转成什么类型呢? 有知道的 谢谢告知!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持html5模板网。

上一篇:超全面的Swift编码规范(推荐) 下一篇:iPhone与iWatch连接、控制、数据传递(Swift)的方法

相关文章

最新文章