前言:如果图片看不了请移步:简书

Touch ID简介


  • Touch ID指纹识别作为iPhone 5s上的“杀手级”功能早已为人们所熟知,目前搭载的设备有iphone SE、iPhone 6、iPhone 6 Plus、iPhone 6s、iPhone 6s Plus、iPad Pro、iPad mini 4、iPad mini 3和iPad air 2
  • iOS 8.0开放了指纹验证的API,为APP增添了新的解锁姿势,Touch ID在iPhone 6、iPhone 6 Plus上表现平平,识别效率低下成为众多用户的吐槽点
  • 苹果在2015新品发布会上提及全新的iPhone 6s、iPhone 6s Plus采用第二代Touch ID,新的Touch ID识别速度更快;实际体验中只要轻轻触碰一下即可,以往要按压半秒钟的指纹识别过程,现在基本是一触即发
  • 随着安卓也有越来越多的设备配备了类似Touch ID的指纹识别装置,今后会有越来越多的APP选择使用指纹识别的验证方式

Touch ID原理


  • Touch ID不存储用户的任何指纹图像,只保存代表指纹的数字字符。iPhone 5s的A7处理器采用了新的高级安全架构,其中有一块名为Secure Enclave的区域用以专门保护密码和指纹数据。只有Secure Enclave可以访问指纹数据,而且它还把这些数据同处理器和系统隔开,因而这些永远不会被存储在苹果的服务器上,也不会被同步到iCloud或其他地方。除了Touch ID之外,它们不会被匹配到其他指纹库中
  • 相信很多人都知道,一个Touch ID传感器和iPhone是一对一的关系,如果损坏,只能售后,无法自行更换,其中的原理比较复杂。一种可能的解释是苹果阻止了任何Touch ID和Secure Enclave之间的任何数据嗅探和截取,实现了特定处理器配对特定的Touch ID。
  • 如果可以随意更换,那么有人将用户的指纹传感器更换,就可以在用户不知情的情况下窃取到指纹数据。苹果的技术降低了这一风险,这意味着不法之徒想要调包传感器的话,需要单独破解每台设备,对于重视安全性的用户来说,这个发现当然是个好消息

Touch ID常用方法与枚举解释


  • 首先苹果提供了canEvaluatePolicy:error:来判断运行的设备是否支持Touch ID

  • 如果要让其失效,可以调用invalidate,新特征:iOS 9.0和Mac OS 10.11

  • 还提供了evaluatePolicy:localizedReason:reply:来验证识别的情况,具体类型如下(以下枚举类型出现的情况均已测试并标注):

        // 身份验证没有成功,因为用户未能提供有效的凭据(连续3次验证失败时提示)
    LAErrorAuthenticationFailed = kLAErrorAuthenticationFailed, // 身份验证被用户取消(当用户点击取消按钮时提示)
    LAErrorUserCancel = kLAErrorUserCancel, // 认证被取消了,因为用户点击回退按钮(当用户点击输入密码时提示)
    LAErrorUserFallback = kLAErrorUserFallback, // 身份验证被系统取消(验证时当前APP被移至后台或者点击了home键导致验证退出时提示)
    LAErrorSystemCancel = kLAErrorSystemCancel, // Touch ID无法启动,因为没有设置密码(当系统没有设置密码的时候,Touch ID也将不会开启)
    LAErrorPasscodeNotSet = kLAErrorPasscodeNotSet, // 无法启动身份验证(这种情况没有检测到,应该是出现硬件损坏才会出现)
    LAErrorTouchIDNotAvailable = kLAErrorTouchIDNotAvailable, // 无法启动身份验证,因为触摸没有注册的手指 (这个暂时没检测到)
    LAErrorTouchIDNotEnrolled = kLAErrorTouchIDNotEnrolled, // 身份验证是不成功的,因为有太多的失败会要求密码解除锁定,(前提是使用 LAPolicyDeviceOwnerAuthenticationWithBiometrics)iOS9和MAC OS0.11新特征
    LAErrorTouchIDLockout NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorTouchIDLockout, // 认证被取消的应用(如无效而认证进行调用)这个暂时没有检测到,可能是苹果预留的 iOS9和MAC OS0.11新特征
    LAErrorAppCancel NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorAppCancel, // LAContext通过这个电话已经失效(当LAContext失效时会调用)iOS9和MAC OS0.11新特征
    LAErrorInvalidContext NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorInvalidContext

Touch 使用


  • 首先,我们需要引入 LocalAuthentication 框架

    	#import <LocalAuthentication/LocalAuthentication.h>
    
    
  • 使用很简单,先创建一个LAContext对象并配置必要的信息

    	LAContext *context = [[LAContext alloc] init];
    // 当指纹识别失败一次后,弹框会多出一个选项,而这个属性就是用来设置那个选项的内容
    context.localizedFallbackTitle = @"使用密码登录";
  • 配置好LAContext对象后,就需要判断一下设备是否支持指纹识别功能

    NSError *error = nil;
    
    if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) { // 该设备支持指纹识别
    
    }else {
    
    }
    
    
  • 当设备支持指纹识别的时候,实现如下

        [context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"身份验证需要解锁指纹识别功能" reply:^(BOOL success, NSError * _Nullable error) {
    if (success) { // 验证成功 }else { NSLog(@"%@", error.localizedDescription);
    switch (error.code) {
    case LAErrorSystemCancel:
    NSLog(@"身份验证被系统取消(验证时当前APP被移至后台或者点击了home键导致验证退出时提示)");
    break;
    case LAErrorUserCancel:
    NSLog(@"身份验证被用户取消(当用户点击取消按钮时提示)");
    break;
    case LAErrorAuthenticationFailed:
    NSLog(@"身份验证没有成功,因为用户未能提供有效的凭据(连续3次验证失败时提示)");
    break;
    case LAErrorPasscodeNotSet:
    NSLog(@"Touch ID无法启动,因为没有设置密码(当系统没有设置密码的时候,Touch ID也将不会开启)");
    break;
    case LAErrorTouchIDNotAvailable:
    NSLog(@"无法启动身份验证"); // 这个没有检测到,应该是出现硬件损坏才会出现
    break;
    case LAErrorTouchIDNotEnrolled:
    NSLog(@"无法启动身份验证,因为触摸标识没有注册的手指"); // 这个暂时没检测到
    break;
    case LAErrorUserFallback:
    {
    [[NSOperationQueue mainQueue] addOperationWithBlock:^{
    NSLog(@"用户选择输入密码,切换主线程处理");
    }];
    break;
    }
    default:
    {
    [[NSOperationQueue mainQueue] addOperationWithBlock:^{
    NSLog(@"其他情况,切换主线程处理"); // 5次失败进入,如果继续验证,则需要输入密码解锁
    }];
    break;
    }
    }
    }
    }
    ];
  • 如果不支持,实现如下

    	NSLog(@"不支持指纹识别");
    switch (error.code) {
    case LAErrorTouchIDNotEnrolled:
    NSLog(@"设备Touch ID不可用");
    break;
    case LAErrorPasscodeNotSet:
    NSLog(@"系统未设置密码");
    break;
    default:
    NSLog(@"TouchID不可用或已损坏");
    break;
    } NSLog(@"%@", error.localizedDescription);

    效果:

  • github-Demo下载请点我—— 如果太慢可以就点我下载

Touch ID使用的更多相关文章

  1. Touch ID 实现

    Touch ID 1.要求 机型:iPhone 5s以上 系统:iOS8以上 框架:#import <LocalAuthentication/LocalAuthentication.h> ...

  2. 微信将推指纹支付 "指付通"会与Touch ID整合吗

    有消息称微信下一版本将推指纹支付“指付通”,解决手机丢失资金安全的问题(这个应该是针对阿里手机支付的弱点),到时候用户绑定的银行卡进行付款时,不用输入密码只需在专门的支付设备(苹果Touch ID ? ...

  3. iOS 使用Touch ID 校验[新增 iOS9 三种错误]

    iOS8后苹果开放了Touch ID的API给开发者,这也给我们的app带来了新的体验.开发者们可使用向第三方应用开放了Touch ID权限的API,以便他们在应用中使用指纹认证来完成用户认证或支付购 ...

  4. 苹果5S指纹扫描识别传感器Touch ID有利于iPhone的安全性

    iPhone5S新增的指纹扫描识别传感器 Touch ID,黑客花了大量的时间表明指纹验证是可以被破解的.即使它可能被黑客攻击,对iPhone5S的安全性而言,仍然具有极大的好处. 为什么一个容易被破 ...

  5. Mate7微信指纹支付来了 比Touch ID整合微信早一点

    之前我们聊过微信将推指纹支付 "指付通"会与Touch ID整合吗这个话题,现在有国内厂商率先支持微信指纹支付,体验一下美国用户使用Apple Pay搭配Touch ID来实现便捷 ...

  6. Touch ID集成

    作者感言 这个国庆由于种种原因, 过的不太安稳, 搬家, 办证, 东跑西跑, 忙的压根就不像是在过节....不过算了, 挑最后一天写写博文.最后:如果你有更好的建议或者对这篇文章有不满的地方, 请联系 ...

  7. IOS 8 关于 Touch ID

    一.什么是Touch ID? Touch ID是在iPhone 5s后的设备上出现的指纹识别.Apple在IOS 8中开放给第三方APP使用. 可以使用 Touch ID 来验证用户的身份,用户经验证 ...

  8. Touch ID指纹解锁使用

    Touch ID是iPhone5S后加入的一项新的功能,也就是大家熟知的指纹识别技术.大家用得最多的可能是手机的解屏操作,不用在和以前一样输入手机的四位数密码进行验证.一方面不用担心密码被别人看到,另 ...

  9. iOS开发——Touch ID 指纹识别

    项目中为了安全性,一般使用密码或iPhone手机的指纹识别Touch ID. 第一步,判断系统是否支持,iOS8.0及以上才支持. 第二步,判断手机是否支持,带Touch ID的手机iPhone5s及 ...

随机推荐

  1. 前端学PHP之语句

    × 目录 [1]if语句 [2]switch [3]while[4]do-while[5]for语句[6]foreach[7]break[8]continue[9]goto 前面的话 任何 PHP 脚 ...

  2. Android沉浸式通知栏设计

    转载博客:http://www.2cto.com/kf/201503/381348.html Android4.4新特性,系统状态栏一体化. 实现的步骤主要有以下几点: 1.android4.4 以上 ...

  3. MVC实用架构设计(三)——EF-Code First(4):数据查询

    前言 首先对大家表示抱歉,这个系列已经将近一个月没有更新了,相信大家等本篇更新都等得快失望了.实在没办法,由于本人水平有限,写篇博客基本上要大半天的时间,最近实在是抽不出这么长段的空闲时间来写.另外也 ...

  4. 关于近段时间论坛型APP 的一段舍弃

    一直以为缓存务必要做的很好,好到什么程度呢,我曾这样想,用户在下滑数刷新的时候也要做到,先加载久缓存再加载新的,同时只改变旧的某些项.这样的想法真的很好!好到我花费了三天去设计数据库和服务器的 php ...

  5. C/C++ char a[ ] 和 char *a 的差别,改变 char *a爆内存错误的原因

    对于一些需要传入参数为 char * temp 指针类的函数: 我们定义一个 char a[10] 或char *a 传进去都是可以的. 但是, 如果该函数是会改变你所传入的参数的值时, 传入 cha ...

  6. 附录E 安装Kafka

    E.1   安装Kafka E.1.1    下载Kafka Kafka是由LinkedIn设计的一个高吞吐量.分布式.基于发布订阅模式的消息系统,使用Scala编写,它以可水平扩展.可靠性.异步通信 ...

  7. SFC的OAM管理框架

    1.简介SFC Service Function Chain(SFC):一系列服务功能的顺序组合,主要是针对网络中的数据包/帧分类处理,还包括能够动态排序部署的网络功能并且这些网络功能间拓扑结构独立, ...

  8. Android TextView中显示图片

    Android官方给我们提供的Html类下面的fromHtml方法 当你需要转换的HTML代码是带图片的,比如<IMG/>,那么你就需要使用到重载的第二个方法了,这个方法里面有个Image ...

  9. WPF老矣,尚能饭否——且说说WPF今生未来(下):安心

    在前面的上.中篇中,我们已经可以看到园子里朋友的点评“后山见! WPF就比winform好! 激情对决”.看到大家热情洋溢的点评,做技术的我也很受感动.老实说,如何在本文收笔--WPF系列文章,我很紧 ...

  10. ActiveX(一)第一个简单的Demo

    说道ActiveX,我的第一直觉就是Flash,利用ActiveX.我们可以创建丰富的可交互式应用程序.同时.利用ActiveX特性.我们可以实现Js 与 ActiveX 的无缝连接(包括数据共享.和 ...