face ID和Touch ID都是iOS开发中常用的安全验证手段,我们通常会在手机解锁、应用内验证身份等操作中使用,下面我们将讲到如何在应用内调用face ID和Touch ID:
权限设置
首先我们需要在info文件中进行隐私权限的设置: 我们添加上图中蓝色标注行的权限,这样我们就有调用face ID或Touch ID的权限了
导入头文件
#import <LocalAuthentication/LocalAuthentication.h>
创建face ID或Touch ID的全部代码
我们利用一个函数来创建其调用代码:
- (void) faceOrTouchID {
LAContext *context = [[LAContext alloc] init];
context.localizedFallbackTitle = @"使用账号密码登陆";
NSError *error = nil;
BOOL isUseFaceOrTouchID = [context canEvaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics error:&error];
if (isUseFaceOrTouchID) {
[context evaluatePolicy:LAPolicyDeviceOwnerAuthenticationWithBiometrics localizedReason:@"请继续验证" reply:^(BOOL success, NSError * _Nullable error) {
if (success) {
dispatch_async(dispatch_get_main_queue(), ^{
NSLog(@"验证成功");
});
} else {
NSLog(@"%@", error.localizedDescription);
switch (error.code) {
case LAErrorSystemCancel: {
NSLog(@"系统取消授权,如其他APP切入");
break;
}
case LAErrorUserCancel: {
NSLog(@"用户取消验证Face ID");
break;
}
case LAErrorAuthenticationFailed: {
NSLog(@"授权失败");
break;
}
case LAErrorPasscodeNotSet: {
NSLog(@"系统未设置密码");
break;
}
case LAErrorBiometryNotAvailable: {
NSLog(@"设备Face ID不可用,例如未打开");
break;
}
case LAErrorBiometryNotEnrolled: {
NSLog(@"设备Face ID不可用,用户未录入");
break;
}
case LAErrorUserFallback: {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
NSLog(@"用户选择输入密码,切换主线程处理");
}];
break;
}
default: {
[[NSOperationQueue mainQueue] addOperationWithBlock:^{
NSLog(@"其他情况,切换主线程处理");
}];
break;
}
}
}
}];
} else {
NSLog(@"不支持Face ID或Touch ID");
switch (error.code) {
case LAErrorBiometryNotEnrolled: {
NSLog(@"Face ID未注册");
break;
}
case LAErrorPasscodeNotSet: {
NSLog(@"未设置密码");
break;
}
default: {
NSLog(@"Face ID不可用");
break;
}
}
NSLog(@"%@",error.localizedDescription);
}
}
以上代码就是创建调用face ID和Touch ID的全部代码,我们可以在适当的应用时机调用此函数实现该验证功能 整体代码非常简洁易懂,其中的两个重点如下:
- (BOOL)canEvaluatePolicy:(LAPolicy)policy error:(NSError * __autoreleasing *)error NS_SWIFT_NOTHROW API_AVAILABLE(macos(10.10), ios(8.0), watchos(3.0), tvos(10.0)); 函数,该函数用来判断设备是否可以调用face ID或Touch ID- (void)evaluatePolicy:(LAPolicy)policy localizedReason:(NSString *)localizedReason reply:(void(^)(BOOL success, NSError * __nullable error))reply NS_SWIFT_ASYNC_THROWS_ON_FALSE(0) API_AVAILABLE(macos(10.10), ios(8.0), watchos(3.0), tvos(10.0)); 函数,该函数用来验证face ID或Touch ID的,会有弹窗弹出来
具体运行效果如下:
开始运行时: 初次验证失败时:
以上就是调用face ID or Touch ID的基础内容。
|