iOS - биометрическая интеграция Face ID
Я интегрировал / реализовал проверку подлинности Face ID (локальной аутентификации) для своего приложения, и все работает нормально, кроме интерфейса окна оповещения приглашения Face ID.
На нем изображен округлый квадрат со светло-серым фоном и заголовком "Идентификатор лица".
Что нужно установить для пустой области точно над заголовком. Это место для значка лица? если да, то как мне это установить? Я перепробовал все в LAContext и LAPolicy.
Посмотрите на этот снимок:
Вот мой код:
let laContext = LAContext()
var error: NSError?
let biometricsPolicy = LAPolicy.deviceOwnerAuthenticationWithBiometrics
if (laContext.canEvaluatePolicy(biometricsPolicy, error: &error)) {
if let laError = error {
print("laError - \(laError)")
return
}
var localizedReason = "Unlock device"
if #available(iOS 11.0, *) {
switch laContext.biometryType {
case .faceID: localizedReason = "Unlock using Face ID"; print("FaceId support")
case .touchID: localizedReason = "Unlock using Touch ID"; print("TouchId support")
case .none: print("No Biometric support")
}
} else {
// Fallback on earlier versions
}
laContext.evaluatePolicy(biometricsPolicy, localizedReason: localizedReason, reply: { (isSuccess, error) in
DispatchQueue.main.async(execute: {
if let laError = error {
print("laError - \(laError)")
} else {
if isSuccess {
print("sucess")
} else {
print("failure")
}
}
})
})
}
1 ответ
Это происходит только в симуляторе, в реальном устройстве холст занят анимацией значка лица.
LocalizedReason предназначен только для Touch ID, поскольку они оба используют один и тот же API.
Обновление 1: добавлены записи экрана:
- iPhone X: https://youtu.be/lklRnLNHyQk
- iPhone 7: https://youtu.be/iIcduvD5JO0
- Симулятор iPhone X: https://youtu.be/bOlRVLIND5c
Все они запускали один и тот же код:
func beginFaceID() {
guard #available(iOS 8.0, *) else {
return print("Not supported")
}
let context = LAContext()
var error: NSError?
guard context.canEvaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, error: &error) else {
return print(error)
}
let reason = "Face ID authentication"
context.evaluatePolicy(.deviceOwnerAuthenticationWithBiometrics, localizedReason: reason) { isAuthorized, error in
guard isAuthorized == true else {
return print(error)
}
print("success")
}
}
Вот рабочий код для TouchID и FaceID со всеми кодами ошибок (Swift 4)
/questions/17635541/protsess-otsenki-face-id-ne-rabotaet-dolzhnyim-obrazom/17635546#17635546
В любой проект, который использует биометрию, включите NSFaceIDUsageDescription ключ в свое приложениеInfo.plist
файл. Без этого ключа система не позволит вашему приложению использовать Face ID.
let authContext = LAContext()
authContext.localizedFallbackTitle = "Use Passcode"
authContext.localizedCancelTitle = "Cancel"
var authError: NSError?
if authContext.canEvaluatePolicy(.deviceOwnerAuthentication, error: &authError) {
evaluatePolicy(policy, context: authContext)
} else {
guard let error = authError else { return }
print("Error: \(error.code)")
checkError(error)
}
private func evaluatePolicy(_ policy: LAPolicy, context: LAContext) {
context.evaluatePolicy(policy, localizedReason: reason) { (success, error) in
if success {
print("Success")
} else {
guard let error = error else { return }
self.checkError(error as NSError)
}
}
}
private func checkError(_ error: NSError) {
guard let error = error as? LAError else { return }
switch error.code {
case .authenticationFailed:
print("authenticationFailed")
requestAuth(policy: .deviceOwnerAuthentication)
case .userFallback:
print("userFallback")
requestAuth(policy: .deviceOwnerAuthentication)
case .userCancel:
print("userCancel")
case .systemCancel:
print("systemCancel")
case .passcodeNotSet:
print("passcodeNotSet")
case .appCancel:
print("appCancel")
case .invalidContext:
print("invalidContext")
case .notInteractive:
print("notInteractive")
default:
checkBioMetricError(error)
}
}
private func checkBioMetricError(_ error: LAError) {
if #available(iOS 11.0, *) {
switch error.code {
case .biometryNotAvailable,
.biometryNotEnrolled,
.biometryLockout:
requestAuth(policy: .deviceOwnerAuthentication)
default: break
}
} else {
switch error.code {
case .touchIDNotAvailable,
.touchIDNotEnrolled,
.touchIDLockout:
requestAuth(policy: .deviceOwnerAuthentication)
default: break
}
}
}