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
但是,有个疑问,我要怎么才能最快的知道 需要强转成什么类型呢? 有知道的 谢谢告知!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
RxSwift学习之Observable的新建、订阅及取消订阅
这篇文章主要给大家介绍了关于RxSwift学习教程之Observable的相关资料,文中详细的给大家介绍了关于新建Observable、订阅Observable和取消订阅并消除内存泄漏等相关的内容,需要的朋友可以参考借鉴,下面来一起看看吧。2017-09-09
最新评论