闲谈
最近一直在追青云志,总觉得电视剧没有小说来的精彩。是的,大咖们演技堪称惊艳,剧情改编也很紧凑,但不得不说很多东西单靠演是达不到的,主人公每一刻的内心也只能在小说中才能看的贴切(为了装X,哥不惜二百两买了一沓正版典藏版)。
看过的童鞋知道,张小凡手中的法宝,是由摄魂与嗜血珠以张小凡精血为媒淬炼而成。而且此法宝,有一特大优秀品质,那就是除了与张小凡有血缘关系的人之外,即便你有通天本领也不能操控,忠诚如此夫复何求啊,说到这里大概就扯到正题了,对的,此法宝自带安全验证功能,类似我们今天的密码校验与指纹识别验证功能。
指纹识别简析
苹果设计的iOS是以安全性为核心的,不管是沙盒机制,还是代码签名等,他们的最终目的都是为了安全。
自iPhone 5S始,苹果公司推出了全新生物安全识别技术—指纹识别验证(Touch ID)。使得我们可以更快、更轻松地对设备进行安全的访问。可贵的是,Touch ID做到了从任意角度读取指纹数据,克服了基于密码进行锁定的不便。除此之外,苹果还加入必须进行密码校验的场景,进一步确保安全,例如【1】:
- 刚开机或重启;
- 超过 48 小时未解锁设备;
- 设备收到了远程锁定命令;
- 五次未能成功匹配指纹;
- 进入Touch ID设置模块或更新新指纹;
最重要的一点,苹果公司提供Touch ID给第三方应用程序使用,程序只会收到认证是否成功的通知,而无法访问 Touch ID 或与已注册指纹相关的数据,这一点对安全而言尤为重要。
为了获得更高的安全性,很多银行类、支付类APP都集成了指纹、手势等二次验证功能。今天我们就重点来谈谈Touch ID集成到APP的具体流程及实现。
流程分析
指纹登录流程:
二次启动后识别登录:
使用过指纹登录的朋友,大概都知道上面的流程。
这个业务实现的难点在于,首次登录成功并启用指纹授权—>退出APP后—>二次启动APP,如何判断是否要启用指纹登录验证呢?这时就需要我们对数据持久化和数据共享有较深的理解,很多APP开发者,在开发登录保持的时候,大都会使用持久化数据的方式,存储成功登录的标记。但对于安全性较高的APP,每次重新启动时都会校验登录状态,单靠持久化数据是不够的。
我的解决方案是:
通过三个数据进行登录保持,
- loginState:持久化数据,用于存储用户登录成功,未激活状态;
- startAutoLoginState:持久化数据,是否开启指纹识别授权;
- isAppCurrentLoginState:共享数据,登录激活状态,该状态的特点,每次重新启动APP都会重新初始化数据。
首次登录:
三个数据变化情况,
状态 | loginState | startAutoLoginState | isAppCurrentLoginState |
---|---|---|---|
登录之前 | nil或NO | nil或NO | NO |
登录成功 | YES | nil或NO | YES |
启用指纹授权 | YES | YES | YES |
不启用授权 | YES | NO | YES |
二次验证登录(指纹登录):
三个数据变化情况,
- 如果loginState和startAutoLoginState同为YES,即可进行指纹登录验证,以下为数据变化情况;
状态 | loginState | startAutoLoginState | isAppCurrentLoginState |
---|---|---|---|
验证之前 | YES | YES | NO |
验证失败 | NO | YES | NO |
验证成功 | YES | YES | YES |
- 否则,重新登录。
核心代码实现
判断设备是否支持指纹识别
指纹登录验证
大致效果:
Demo GitHub下载链接: EVNTouchIDDemo.git,如果有用,给个Star……
参考文献:
【1】iOS security guide;
【2】Apple Objective-C;
【3】Apple Swift API.