是否可以仅使用密码进行身份验证,即使设备在ios,swift中具有触摸ID功能

时间:2017-10-13 06:21:26

标签: ios iphone swift passcode localauthentication

我想使用PassCode即使设备具有Touch ID功能,仅对 进行身份验证。我正在使用.deviceOwnerAuthentication评估政策方法。当我使用它时,

  
      
  • 如果用户已注册触摸ID - >总是要求触摸id
  •   
  • 如果使用尚未注册触摸ID - >然后只询问密码
  •   

我想要的是,即使用户已注册touch id,也只询问passcode。希望你的帮助。

2 个答案:

答案 0 :(得分:0)

@Anuradh,因为我们无法在我们的应用程序中使用iOS的密码进行身份验证,除非我们使用TouchID,否则我认为没有办法提示只显示默认的密码屏幕。它是私有API。您最好的选择是使用自定义密码屏幕。您可以查看“ABPadLockScreen”:https://github.com/abury/ABPadLockScreen

答案 1 :(得分:0)

这可以通过将SecAccessControl设置为SecAccessControlCreateFlags,并使用.devicePasscode的安全框架来完成。

添加钥匙串项目,

let secAccessControlbject: SecAccessControl = SecAccessControlCreateWithFlags(kCFAllocatorDefault,
                                                                      kSecAttrAccessibleWhenUnlockedThisDeviceOnly,
                                                                      .devicePasscode,
                                                                      nil)!
    let dataToStore = "AnyData".data(using: .utf8)!


    let insertQuery: NSDictionary = [
        kSecClass: kSecClassGenericPassword,
        kSecAttrAccessControl: secAccessControlbject,
        kSecAttrService: "PasscodeAuthentication",
        kSecValueData: dataToStore as Any,
    ]

    let insertStatus = SecItemAdd(insertQuery as CFDictionary, nil)

要通过“密码”屏幕进行身份验证,请访问保存的项目,

 let query: NSDictionary = [
        kSecClass:  kSecClassGenericPassword,
        kSecAttrService  : "PasscodeAuthentication",
        kSecUseOperationPrompt : "Sign in"
    ]

    var typeRef : CFTypeRef?

    let status: OSStatus = SecItemCopyMatching(query, &typeRef) //This will prompt the passcode.

    if (status == errSecSuccess)
    {
       print("Authentication Success")
    }