ios 8开放指纹认证(Touch ID)操作使用

简介:    iOS 8的SDK开放了Touch ID的接口.从WWDC的视频中可以看到Touch ID应用在两个方面:用于Key Chain加密和用于授权.iOS 8正式版发布以后我们可以看到Evernote的iOS app已经集成了该功能.
   iOS 8的SDK开放了Touch ID的接口.从WWDC的视频中可以看到Touch ID应用在两个方面:用于Key Chain加密和用于授权.iOS 8正式版发布以后我们可以看到Evernote的iOS app已经集成了该功能.下面来看看如何实现使用Touch ID进行身份认证.
  其实很简单,用于身份认证的所有的接口都在LocalAuthentication framework中, 该framework实际上只有三个头文件:
  LAContext.h
  LAError.h
  LAPublicDefines.h
  而实际用到的函数也只有两个:
  // 用来判断设备是否支持Touch ID
  - ( BOOL )canEvaluatePolicy:( LAPolicy )policy error:( NSError  *  __autoreleasing  *)error;
  // 真正验证身份的函数
   - ( void )evaluatePolicy:( LAPolicy )policy
       localizedReason:( NSString   *)localizedReason
                 reply:(
void (^)( BOOL   success,   NSError   *error))reply;

  上述两个函数都是LAContext的member function.目前LAPolicy只有一个值:  LAPolicyDeviceOwnerAuthenticationWithBiometrics.

  如果canEvaluatePolicy返回YES,表示设备支持指纹识别,那么便可以调用evaluatePolicy:函数进行指纹识别了.调用evaluatePolicy函数后会弹出一个alert,如下图:



  该alert可定制的只有两处:
  1.”To access your photos”提示文字是由 localizedReason参数指定的,用来向用户说明使用Touch ID的目的.
  2.”Enter Password”可由LAContext的localizedFallbackTitle属性设置(LAContext目前只有这一个属性),如果不设置的话,默认是”Enter Password”.值得注意的是,如果该属性设置为@“”(空字符串),该按钮会被隐藏,Evernote应该就是这么做的.
  其他的免谈,当然更别提获取用户的指纹数据了.
  理论上三种情况下会退出验证(alert会被dismiss,reply回调会被调用):
  1.用户指纹通过验证
  2.用户点击”Enter Password”按钮
  3.用户点击”Cancel”按钮
  还有一种情况:用户输入了错误的指纹.这种情况下,该alert不会被dismiss,其标题会由”Touch ID”改为”Try Again”,有弹簧状的动画效果过渡.好了,代码如下(不要忘了引入头文件   <LocalAuthentication/LocalAuthentication.h> ):
    LAContext  *context = [ LAContext  new ];
   
   
  NSError  *error;
    context.
localizedFallbackTitle  =  @"" ;
   
   
  if  ([context  canEvaluatePolicy : LAPolicyDeviceOwnerAuthenticationWithBiometrics  error :&error]) {
       
  NSLog ( @"Touch ID is available." );
        [context
  evaluatePolicy : LAPolicyDeviceOwnerAuthenticationWithBiometrics  
                localizedReason : NSLocalizedString ( @"Use Touch ID to log in." ,  nil
                          reply :^( BOOL  success,  NSError  *error) {
             if  (success) {
               
  NSLog ( @"Authenticated using Touch ID." );
            }
  else  {
                 if  (error. code  ==  kLAErrorUserFallback ) {
                     NSLog ( @"User tapped Enter Password" );
                }
  else  if  (error. code  ==  kLAErrorUserCancel ) {
                   
  NSLog ( @"User tapped Cancel" );
                }
  else  {
                   
  NSLog ( @"Authenticated failed." );
            }
        }];
    }
  else  {
       
  NSLog ( @"Touch ID is not available: %@" , error);
    }
    在开发中遇到过一个问题, 不知道是不是bug, 就是启动程序后立即使用Touch ID, 这样会导致身份验证通过了, 但是上述的alert并不会被dismiss. 详情参见 https://github.com/RungeZhai/TouchIDIssue
相关文章
|
8月前
|
API 定位技术 iOS开发
IOS开发基础知识:什么是 Cocoa Touch?它在 iOS 开发中的作用是什么?
IOS开发基础知识:什么是 Cocoa Touch?它在 iOS 开发中的作用是什么?
110 2
|
iOS开发 开发者
📝 App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
在iOS应用程序开发过程中,进行App备案并获取公钥及证书SHA-1指纹是至关重要的步骤。本文将介绍如何通过appuploader工具获取iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹,帮助开发者更好地理解和应用该过程。
|
6月前
|
开发工具 iOS开发 计算机视觉
|
3月前
|
程序员 iOS开发 开发者
iOS|获取 Distribution Managed 证书的 SHA-1 指纹和公钥
APP 备案时,如何获取 iOS 平台 Distribution Managed 类型证书的证书的 SHA-1 指纹和公钥?
88 0
|
5月前
|
iOS开发
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
255 0
App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法
|
8月前
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
446 0
|
Android开发 iOS开发 开发者
App备案-iOS云管理式证书 Distribution Managed 公钥及证书SHA-1指纹的获取方法
,在appuploder直接复制IOS信息;如果还没有创建证书,请上传正确的P12苹果证书后,系统会自动解析出对应的签名和公钥信息; ——APP备案的原理是基于原有的工信部域名备案系统,如果已经有了域名备案,无需新增备案主体;只需要在之前的域名备案系统里面,新增APP信息,收集的APP信息主要包括APP包名和签名及公钥这3项;——APP备案是属于行政常规主体信息预存,和域名一样,自行决定是否备案。目前国内安卓应用商店是全面要求APP备案的,如果没有APP备案是不能通过审核发布到各大应用商店。——如看了教程,还不清楚怎么获取APP包名、安卓签名、苹果sha1签名、公钥等信息,请联系我们在线客服,
|
8月前
|
API 定位技术 iOS开发
IOS开发基础知识:什么是 Cocoa Touch?它在 iOS 开发中的作用是什么?
【4月更文挑战第18天】**Cocoa Touch** 是iOS和Mac OS X应用的核心框架,包含面向对象库、运行时系统和触摸优化工具。它提供Mac验证的开发模式,强调触控接口和性能,涵盖3D图形、音频、网络及设备访问API,如相机和GPS。是构建高效iOS应用的基础,对开发者至关重要。
79 0
|
8月前
|
iOS开发
你知道IOS移动端到操作手势有哪些吗?
你知道IOS移动端到操作手势有哪些吗?
148 0