zoukankan      html  css  js  c++  java
  • 【源码】iOS指纹解锁Touch ID的开发

    指纹解锁原理:

    苹果在文件中对iPhone 5S配备的Touch ID指纹识别系统的功能与工作原理进行了详细说明。文件对iPhone 5S的A7处理器中““Secure Enclave””协处理器进行了说明,该协处理器能够安全地将用户储存的指纹信息与Touch ID当前所识别到的指纹进行信息对比。而苹果早在iPhone 5S发布时就公布了Touch ID的工作原理。但此次所获悉的文件说明得更为详细。

    根据苹果的解释,一个单一的注册指纹与别人指纹出现随机匹配的概率为五万分之一。

    苹果声称““Secure Enclave””模块系统能够安全地管理并识别用户的指纹,并将用户的指纹信息独立地保存在别的系统中,同时通过加密内存和一个硬件随机数字密码发生器进行管理。

    每个“Secure Enclave”是单独设置的,不能访问系统其他部分的,拥有自己的独立的UID(唯一的ID),连苹果也不知道这些UID。当设备启动时,Touch ID会临时创建一个秘钥,与“Secure Enclave”的UID配合,对设备的内存空间进行加密。

    而在苹果发布的文件中,苹果对A7处理器进行指纹识别授权的描述是:A7和Touch ID之间通过一个串行外设接口总线进行通信。A7处理器将数据发到“Secure Enclave”,但并不对数据内容进行读取。加密和身份验证都是使用Touch ID和“Secure Enclave”之间的共享密钥。通信密钥交换使用双方提供的一个随机AES密钥,并随机建立会话密钥和使用AES-CCM传输加密。

    由于大部分的Touch ID用户可能发现,在某些情况下需要使用密码来代替Touch ID。而这份文件指出了什么情况下Touch ID不能使用和要求必须输入密码:

    文件指出在以下情况下密码可以代替Touch ID:

    -iPhone 5s刚刚开启或重新启动时;

    -iPhone 5s没有解锁超过48小时;

    -经过5次不成功指纹匹配时;

    -当进行设置或使用新的手指纹使用Touch ID时;

    -iPhone 5s已经接收到远程锁定命令时。

    指纹解锁代码实现:

    所以我们一开始需要判断当前系统版本


    低于8.0的系统版本不支持指纹解锁

    当系统版本大于8.0时,引入并导入头文件,书写代码!

     
     
     

    //指纹识别

    -(void)safeToFaceID

    {

        if ([[UIDevice currentDevice] systemVersion].floatValue > 8.0) {

            //新建LAContext实例

            LAContext  *authenticationContext= [[LAContext alloc]init];

            NSError *error;

            //LAPolicyDeviceOwnerAuthentication

            //1:检查Touch ID 是否可用

            if ([authenticationContext canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error]) {

                NSLog(@"touchId 可用");

                //2:执行认证策略

                [authenticationContext evaluatePolicy:LAPolicyDeviceOwnerAuthentication localizedReason:@"请输入您的指纹进入应用" reply:^(BOOL success, NSError * _Nullable error) {

                    if (success) {

                        NSLog(@"通过了Touch Id指纹验证");

                    }else{

                        if (error.code == -2) {//点击了取消按钮

                            NSLog(@"点击了取消按钮");

                            NSLog (@"****** exit******");

                            exit (0);

                        }else if (error.code == -4){//按下电源键

                            NSLog(@"按下电源键");

                            NSLog (@"****** exit******");

                            exit (0);

                        }

                        //                else if (error.code == -7){//在有TouchID 的功能下,没有设置TouchID的运行结果

                        //                else if (error.code == -6){//在iphone5上运行结果(没有指纹解锁功能)

                        //                else if (error.code == -8){//输入错误3次

                        //                else if (error.code == -1){//连续三次指纹识别错误

                        //                NSLog(@"未通过Touch Id指纹验证,错误描述: %@---", error.description);

                    }

                }];

            }else{//Touch ID功能被锁定,下一次需要输入系统密码

                NSLog(@"touchId 不可用");

                NSLog(@"error====%@",error.description);

                //提示用户不可用

                //        ?????

            }

            return;

        }

    }

    以下是经常出现的几个错误,大家共勉!

    例如,在iphone5上运行结果:

    Error Domain=com.apple.LocalAuthentication Code=-6 "Biometry is not available on this device." UserInfo=0x15ec5a00 {NSLocalizedDescription=Biometry is not available on this device.

    例如,在模拟器上运行结果:

    Error Domain=com.apple.LocalAuthentication Code=-1000 "Simulator is not supported." UserInfo=0x7ffe604b0790 {NSLocalizedDescription=Simulator is not supported.

    例如,在有TouchID 的功能下,没有设置TouchID的运行结果:

    Error Domain=com.apple.LocalAuthentication Code=-7 "No fingers are enrolled with Touch ID." UserInfo=0x170075fc0 {NSLocalizedDescription=No fingers are enrolled with Touch ID.

    例如:连续三次指纹识别错误:

    Error Domain=com.apple.LocalAuthentication Code=-1 "Aplication retry limit exceeded." UserInfo=0x1740797c0 {NSLocalizedDescription=Aplication retry limit exceeded.}

    例如:用户在Touch ID对话框中点击了取消按钮:

    Error Domain=com.apple.LocalAuthentication Code=-2 "Canceled by user." UserInfo=0x17006c780 {NSLocalizedDescription=Canceled by user.

    例如:用户在Touch ID对话框中点击输入密码按钮:

    Error Domain=com.apple.LocalAuthentication Code=-3 "Fallback authentication mechanism selected." UserInfo=0x17407e040 {NSLocalizedDescription=Fallback authentication mechanism selected.

    例如:按下电源键:

    Error Domain=com.apple.LocalAuthentication Code=-4 "UI canceled by system." UserInfo=0x170065900 {NSLocalizedDescription=UI canceled by system.}

    例如:Touch ID功能被锁定,下一次需要输入系统密码时的运行结果:

    Error Domain=com.apple.LocalAuthentication Code=-8 "Biometry is locked out." UserInfo={NSLocalizedDescription=Biometry is locked out.



  • 相关阅读:
    Linux sed命令
    Linux之read命令使用
    Linux shell之数组
    Linux Shell脚本攻略:shell中各种括号()、(())、[]、[[]]、{}的作用
    shell中的${},##, %% , :- ,:+, ? 的使用
    hostname命令
    进度条的制作-python
    33 Python 详解命令解析
    Python 学习笔记 多进程 multiprocessing--转载
    Spring注解(生命周期)
  • 原文地址:https://www.cnblogs.com/wangbinios/p/7654936.html
Copyright © 2011-2022 走看看