iOS - TouchID 指纹识别

简介: 前言 NS_CLASS_AVAILABLE(10_10, 8_0) @interface LAContext : NSObject指纹识别功能是 iPhone 5s 推出的,SDK 是 iOS 8.0 推出。

前言

    NS_CLASS_AVAILABLE(10_10, 8_0) @interface LAContext : NSObject
  • 指纹识别功能是 iPhone 5s 推出的,SDK 是 iOS 8.0 推出。

  • 推出指纹识别的主要原因是为了简化支付,移动支付的环节越简单越好。

  • 1)指纹验证方式:

        // 只使用指纹验证
        LAPolicyDeviceOwnerAuthenticationWithBiometrics NS_ENUM_AVAILABLE(NA, 8_0) = kLAPolicyDeviceOwnerAuthenticationWithBiometrics,
    
        // 使用指纹和设备密码验证,指纹错误或无法验证时会自动跳转到输入密码验证界面
        LAPolicyDeviceOwnerAuthentication NS_ENUM_AVAILABLE(10_11, 9_0) = kLAPolicyDeviceOwnerAuthentication                                
  • 2)指纹验证错误信息:

        // 指纹无法识别                        error.code == -1
        LAErrorAuthenticationFailed = kLAErrorAuthenticationFailed,
    
        // 用户点击了 "取消" 按钮               error.code == -2
        LAErrorUserCancel           = kLAErrorUserCancel,
    
        // 用户取消,点击了 "输入密码" 按钮       error.code == -3
        LAErrorUserFallback         = kLAErrorUserFallback,
    
        // 系统取消,例如激活了其他应用程序        error.code == -4
        LAErrorSystemCancel         = kLAErrorSystemCancel,
    
        // 验证无法启动,因为设备上没有设置密码     error.code == -5
        LAErrorPasscodeNotSet       = kLAErrorPasscodeNotSet,
    
        // 验证无法启动,因为设备上没有 Touch ID   error.code == -6
        LAErrorTouchIDNotAvailable  = kLAErrorTouchIDNotAvailable,
    
        // 验证无法启动,因为没有输入指纹          error.code == -7
        LAErrorTouchIDNotEnrolled   = kLAErrorTouchIDNotEnrolled,
    
        LAErrorTouchIDLockout   NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorTouchIDLockout,
        LAErrorAppCancel        NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorAppCancel,
        LAErrorInvalidContext   NS_ENUM_AVAILABLE(10_11, 9_0) = kLAErrorInvalidContext

1、指纹识别的使用

  • Objective-C

        // 包含本地身份验证头文件
        #import <LocalAuthentication/LocalAuthentication.h>
    
        // 判断用户手机系统是否是 iOS 8.0 以上版本
        if ([UIDevice currentDevice].systemVersion.floatValue < 8.0) {                                                              
            return;
        }
    
        // 实例化本地身份验证上下文
        LAContext *context= [[LAContext alloc] init];
    
        // 判断是否支持指纹识别
        if (![context canEvaluatePolicy:LAPolicyDeviceOwnerAuthentication error:NULL]) {                            
            return;
        }
    
        [context evaluatePolicy:LAPolicyDeviceOwnerAuthentication 
                localizedReason:@"请验证已有指纹" 
                          reply:^(BOOL success, NSError * _Nullable error) {
    
            // 输入指纹开始验证,异步执行
            if (success) {
    
                [self refreshUI:[NSString stringWithFormat:@"指纹验证成功"] message:nil];
    
            } else {
    
                [self refreshUI:[NSString stringWithFormat:@"指纹验证失败"] message:error.userInfo[NSLocalizedDescriptionKey]];
            }
        }];
    
        // 主线程刷新 UI
        - (void)refreshUI:(NSString *)str message:(NSString *)msg {
    
            dispatch_async(dispatch_get_main_queue(), ^{
    
                UIAlertController *alert = [UIAlertController alertControllerWithTitle:str 
                                                                               message:msg 
                                                                        preferredStyle:UIAlertControllerStyleAlert];
    
                [self presentViewController:alert animated:YES completion:^{
    
                    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
                        [alert dismissViewControllerAnimated:YES completion:nil];
                    });
                }];
            });
        }
  • 效果

    TouchID1TouchID2

    TouchID3TouchID4

2、指纹识别的设置

  • Objective-C

        // 判断是否支持指纹识别
        if (![context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:NULL]) {
    
        }
    
        // 取消指纹验证
        [context invalidate];
    
        // 设置 输入密码 按钮的标题
        context.localizedFallbackTitle = @"输入密码按钮标题";
    
        // 设置 取消 按钮的标题
        context.localizedCancelTitle = @"取消按钮标题";
目录
相关文章
|
4月前
|
iOS开发 开发者
📝 App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
在iOS应用程序开发过程中,进行App备案并获取公钥及证书SHA-1指纹是至关重要的步骤。本文将介绍如何通过appuploader工具获取iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹,帮助开发者更好地理解和应用该过程。
|
1月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
89 0
|
5月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
,在appuploder直接复制IOS信息;如果还没有创建证书,请上传正确的P12苹果证书后,系统会自动解析出对应的签名和公钥信息; ——APP备案的原理是基于原有的工信部域名备案系统,如果已经有了域名备案,无需新增备案主体;只需要在之前的域名备案系统里面,新增APP信息,收集的APP信息主要包括APP包名和签名及公钥这3项;——APP备案是属于行政常规主体信息预存,和域名一样,自行决定是否备案。目前国内安卓应用商店是全面要求APP备案的,如果没有APP备案是不能通过审核发布到各大应用商店。——如看了教程,还不清楚怎么获取APP包名、安卓签名、苹果sha1签名、公钥等信息,请联系我们在线客服,
|
3月前
|
iOS开发 开发者
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
283 0
|
3月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
107 0
|
传感器 安全 生物认证
iOS传感器开发——为APP添加手机密码、指纹进行安全验证
iOS传感器开发——为APP添加手机密码、指纹进行安全验证
218 0
iOS传感器开发——为APP添加手机密码、指纹进行安全验证
|
API iOS开发
iOS 关于指纹验证LocalAuthentication
IMG_0152.PNG 最近做项目版本更新有个需求是 3DTouch解锁功能, 由此原因接触 Apple的指纹解锁功能, 基本功能原先已经实现好了,发现了一个 Bug然后来优化一下,先扯会儿等下我会附上源代码, 其实在指纹解锁功能上 Apple已经帮我们封装好了, 我们需要写的代码其实并不多。
1490 0
|
iOS开发
ios 8开放指纹认证(Touch ID)操作使用
   iOS 8的SDK开放了Touch ID的接口.从WWDC的视频中可以看到Touch ID应用在两个方面:用于Key Chain加密和用于授权.iOS 8正式版发布以后我们可以看到Evernote的iOS app已经集成了该功能.
805 0