TouchID 指纹识别

指纹识别

TouchID 指纹识别是iPhone 5s设备新增的一项重大功能,用于数据加密和安全。而在IOS 8.0 以后也向第三方开放了相应功能API,我们可以利用这个API做相应的用户验证和登录的功能,省去输入密码的环节,提高登录的用户体验。
在app中集成指纹识别是跟系统解锁iPhone用的一套指纹识别,就是说假如在app中指纹识别错误了5次(iOS 系统默认指纹识别错误5次后,指纹识别会被判定为无效状态),那么不仅app中的指纹识别系统是无效的,系统的iPhone指纹识别解锁系统也是无效的,必须输入iPhone解锁口令码验证之后,指纹识别才会被系统重新判别为有效!

我在这里说下指纹登录的流程:

在设备第一次使用指纹登录之前,必须先登录原有的账号
在密码管理中,点击开启“指纹登录”;
验证TouchID:检测当前设备是否支持TouchID,若支持则发起TouchID验证;
生成设备账号/密码:TouchID验证通过后,根据当前已登录的账号和硬件设备Token,生成设备账号/密码(规则可自定,密码要长要复杂),并保存在keychain;
绑定:生成设备账号/密码后,将原账号及设备账号/密码,加密后(题主使用的是RSA加密)发送到服务端进行绑定;
成功:验证原账号及设备账号有效后,返回相应状态,绑定成功则完成整个TouchID(设备)绑定流程。

设备(指纹)登陆
在设备(用户)绑定之后,并且用户账号退出后,可以使用指纹登录,若当前设备未绑定,则不会出现“指纹登录”按钮
TouchID登录:在用户登录界面,点击“指纹登录”;
验证TouchID:检测当前设备是否支持TouchID,若支持则发起TouchID验证;
登录:读取app在本机的设备账号/密码,调用设备登录接口,发起登录请求;
成功:验证设备账号/密码后,返回相应状态,登录成功则完成整个TouchID登录流程。
*在设备(用户)绑定之后,并且当前正处于登录状态,也可以将本设备取消绑定,流程基本与绑定流程雷同,不再重复。

具体用法如下:

导入头文件

#import <LocalAuthentication/LocalAuthentication.h>

使用LocalAuthentication中的LAContext.h和LAError.h两个头文件,LAError.h提供错误码

初始化LAContext对象(创建安全验证对象)
LAContext *context = [[LAContext alloc] init];
LAPolicy这个属性是一个枚举,它提供两个值:

LAPolicyDeviceOwnerAuthenticationWithBiometrics是生物指纹识别。支持iOS 8以上系统,使用该设备的TouchID进行验证,当输入TouchID验证5次失败后,TouchID被锁定,只能通过锁屏后解锁设备时输入正确的解锁密码来解锁TouchID。验证弹框有两个按钮,第一个是取消按钮,第二个按钮可以自定义标题名称(默认是"输入密码")。只有在第一次指纹验证失败后才会出现第二个按钮,这种鉴定方式的第二个按钮的功能自定义,第二个按钮的功能不做处理的话不会有任何响应。
LAPolicyDeviceOwnerAuthentication是生物指纹识别或系统密码验证。支持iOS9以上系统,对于8.0系统的手机不能使用。如果TOUCH ID 可用,且已经录入指纹,则优先调用指纹验证。其次是调用系统密码验证,如果没有开启设备密码,则不可以使用这种验证方式。指纹识别验证失败三次将自动弹出设备密码输入框,如果不进行密码输入。再次进来还可以有两次机会验证指纹,如果都失败则TOUCH ID被锁住。以后也只能弹出设备密码输入框。补充:值得注意的是在iOS9系统中,前三次验证失败会自动弹出密码验证框,后两次验证失败后不会自动弹出密码验证框。而在iOS 10系统中,前三次验证失败或者后两次验证失败,都会自动弹出密码验证框。

看下两种验证方式在各系统中的执行情况

LAPolicyDeviceOwnerAuthenticationWithBiometrics

iOS8系统:
     在只有口令密码的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     在只有指纹的情况下打印结果: NSLog(@"指纹识别无效%@",error.localizedDescription);
     在没有口令也没有指纹的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     
     iOS9系统:
     在只有口令密码的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     在只有指纹的情况下打印结果: NSLog(@"指纹识别无效%@",error.localizedDescription);
     在没有口令也没有指纹的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     
     iOS10系统:
     在只有口令密码的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     在只有指纹的情况下打印结果: NSLog(@"指纹识别无效%@",error.localizedDescription);
     在没有口令也没有指纹的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     分析可知,在LAPolicyDeviceOwnerAuthenticationWithBiometrics下必须系统口令码和指纹同时是存在的,才会判定指纹系统是可用的。

LAPolicyDeviceOwnerAuthentication

iOS9系统:
     在只有口令密码的情况下打印结果:NSLog(@"指纹识别有效");
     在只有指纹的情况下打印结果: NSLog(@"指纹识别无效%@",error.localizedDescription);
     在没有口令也没有指纹的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     
     iOS10系统:
     在只有口令密码的情况下打印结果:NSLog(@"指纹识别有效");
     在只有指纹的情况下打印结果: NSLog(@"指纹识别无效%@",error.localizedDescription);
     在没有口令也没有指纹的情况下打印结果:NSLog(@"指纹识别无效%@",error.localizedDescription);
     综合iOS9、iOS10在policy:LAPolicyDeviceOwnerAuthentication下的表现,只要开启了系统口令码,就判定指纹系统可用,更加印证了 如果没有开启设备密码,则不可以使用这种验证方式。
官方API仅提供TouchID的支持状态和验证状态:

canEvaluatePolicy
监测设备是否支持TouchID,返回BOOL,并且若不支持,则在error里面返回相应状态
evaluatePolicy
监测TouchID验证状态,若验证错误则在block里面返回验证状态和error错误原因

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
    //创建安全验证对象
    LAContext *context = [[LAContext alloc] init];
    //不设置,默认是取消
    context.localizedCancelTitle = @"切换其他支付方式";
    //不设置的话,验证失败会显示输入密码的按钮,设置了就没有这个按钮
    context.localizedFallbackTitle = @"";
    
    
    //错误对象
    NSError *error = nil;
    NSString *result = @"请验证已有指纹";
    
    
    //判断支持 touch ID
    if ([context canEvaluatePolicy:LAPolicyDeviceOwnerAuthentication error:&error]) {

        //可以调用 touch ID
        [context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:result reply:^(BOOL success, NSError *error) {

            if (success) {
                
                NSLog(@"touch ID 正确,回主线程刷新UI");
//                dispatch_async(dispatch_get_main_queue(), ^{
                
//                });
            }else{

                if(error.code == kLAErrorBiometryLockout) {

                    NSLog(@"连续五次指纹识别错误,TouchID功能被锁定,下一次需要输入系统密码");
                    
                    [context evaluatePolicy:LAPolicyDeviceOwnerAuthentication localizedReason:result reply:^(BOOL success, NSError * _Nullable error) {
                        
                        if (success) {
                            NSLog(@"---系统密码正确");
                        }else{
                            NSLog(@"---系统密码错误5次后,要延迟等待时间了");
                        }
                    }];
                    
                }else
                    
                    if(error.code == LAErrorAppCancel) {

                    NSLog(@"认证被取消了由用户(例如了取消按钮");
                }else if(error.code == LAErrorInvalidContext) {

                    NSLog(@"LAContext传递给这个调用之前已经失效(请求验证出错)");
                }else if(error.code == LAErrorAuthenticationFailed) {

                    NSLog(@"连续三次指纹识别错误");
                    
                }else if (error.code == LAErrorUserFallback){

                    NSLog(@"用户选择输入密码,切换主线程处理");
                    
                }else if (error.code == LAErrorSystemCancel){

                    NSLog(@"身份验证被系统取消了(如另一个应用程序去前台)。");
                }else if (error.code == LAErrorPasscodeNotSet){

                    NSLog(@"设备系统未设置密码");
                }else if (error.code == kLAErrorTouchIDNotAvailable){

                    NSLog(@"设备未设置Touch ID,因为设备上无法使用Touch ID。");
                }else if (error.code == kLAErrorTouchIDNotEnrolled){
                    
                    NSLog(@"用户未录入指纹");
                }else  if (error.code == LAErrorUserCancel){
                    NSLog(@"用户点击了取消----更换支付方式");
                }else{
                    NSLog(@"原因未知");
                }
            }

        }];
    }else{
        NSLog(@"不支持touch ID  ,只能用密码了");
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容