swift3.0 指纹解锁实现

本文介绍了在使用Swift 3.0重写项目时,实现指纹解锁功能所遇到的问题,特别是如何处理`evaluatePolicy`方法中`Error`类型的回调。在Swift 2中,可以直接获取`Error.code`进行错误处理,但在Swift 3.0中,由于类型检查的严格性,需要将`Error`强转为`LAError`。作者对于如何快速确定正确转换类型的问题提出了疑问,并欢迎读者交流讨论。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近学习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
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值