在 iPhone 5s 之后,Home 键有了指纹解锁功能。这给我们提供了了一种既安全又方便的的解锁方式。




1、载入 LocalAuthentication Framework

若要使用这个功能,我们必须让 app 加载 iOS 的本地认证框架。

使用Swift实现Touch ID(指纹解锁) 1

使用Swift实现Touch ID(指纹解锁) - 敏捷大拇指 - 使用Swift实现Touch ID(指纹解锁) 1

使用Swift实现Touch ID(指纹解锁) 2

使用Swift实现Touch ID(指纹解锁) - 敏捷大拇指 - 使用Swift实现Touch ID(指纹解锁) 2





2、在类文件中导入 LocalAuthentication

[Swift] 纯文本查看 复制代码
import LocalAuthentication





3、建立 Context

在使用 Touch ID 之前,需要先获得一个上下文对象,来管理操作指纹解锁的过程。在整个过程中可能会因为设备条件以及用户操作等原因出现很多异常,我们建立一个 NSError 对象来获取异常。

[Swift] 纯文本查看 复制代码
func touchID (){
  let context = LAContext()
  var error: NSError?
}





4、判断设备是否支持指纹识别

[Swift] 纯文本查看 复制代码
func touchID (){
  let context = LAContext()
  var error: NSError?

if context.canEvaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, error: &error) {
  // 下面是开始指纹解锁的代码
}


这里 context 对象执行 canEvaluatePolicy 方法来判断设备是否支持。第二个参数是 NSError 类的指针类型。




5、捕获错误

我们在这里写一个函数来捕获错误原因并且记录错误信息,虽然这不是必须的,但是一个好的交互设计通常会考虑这些:

[Swift] 纯文本查看 复制代码
func errorMessageForLAErrorCode(errorCode: Int) -> String {
    var message = ""

    switch errorCode {
    case LAError.appCancel.rawValue:
        message = "Authentication was cancelled by application"

    case LAError.authenticationFailed.rawValue:
        message = "The user failed to provide valid credentials"

    case LAError.invalidContext.rawValue:
        message = "The context is invalid"

    case LAError.passcodeNotSet.rawValue:
        message = "Passcode is not set on the device"

    case LAError.systemCancel.rawValue:
        message = "Authentication was cancelled by the system"

    case LAError.touchIDLockout.rawValue:
        message = "Too many failed attempts."

    case LAError.touchIDNotAvailable.rawValue:
        message = "TouchID is not available on the device"
        showPassWordInput()

    case LAError.userCancel.rawValue:
        message = "The user did cancel"

    case LAError.userFallback.rawValue:
        message = "The user chose to use the fallback"

    default:
        message = "Did not find error code on LAError object"
    }
    return message
}


这个函数接受错误代码,并且返回错误信息,这样我们便可以清晰的了解各个异常状况的发生时机。




6、开始指纹解锁

[Swift] 纯文本查看 复制代码
func touchID (){
  let context = LAContext()
  var error: NSError?

if context.canEvaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, error: &error) {

  // 开始进入识别状态,以闭包形式返回结果。闭包的 success 是布尔值,代表识别成功与否。error 为错误信息。
  context.evaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, localizedReason: "请用指纹解锁", reply: {success, error in

    if success {
    // 成功之后的逻辑, 通常使用多线程来实现跳转逻辑。
    }else {
      if let error = error as? NSError {
        // 获取错误信息
        let message = self.errorMessageForLAErrorCode(errorCode: error.code)
        print(message)
      }
    }

  })
}


运行起来,就可以体验指纹解锁功能啦。不过有个小瑕疵,当指纹录入失败之后,点击输入密码,什么都不会发生。我们解锁iPhone的时候可以调用系统的密码输入视图,但是在应用里调用系统的密码输入视图是不允许的。我们需要借助第三方框架或者自己写一个吧……




作者:CyrusCao