我在这方面遇到了困难:
我们的应用程序使用TouchID从KeyChain中检索用于对WKWebView中的WebApp进行身份验证的机密。当用户成功通过TouchID进行身份验证时,一切都很好。
当用户使TouchID失败,然后点击“输入密码”以通过设备密码进行身份验证时,就会出现问题。我注意到呈现的屏幕是纯白色的,并且密码文本框在被屏蔽之前不会显示最后输入的字符的值,从而产生了奇怪的用户体验。在我看来,这似乎是个错误,除非我某种程度上缺少配置要求。

    // global arguments for the touchId keychain queries
    let kSecClassValue = NSString(format: kSecClass)
    let kSecAttrAccountValue = NSString(format: kSecAttrAccount)
    let kSecValueDataValue = NSString(format: kSecValueData)
    let kSecClassGenericPasswordValue = NSString(format: kSecClassGenericPassword)
    let kSecAttrServiceValue = NSString(format: kSecAttrService)
    let kSecMatchLimitValue = NSString(format: kSecMatchLimit)
    let kSecReturnDataValue = NSString(format: kSecReturnData)
    let kSecMatchLimitOneValue = NSString(format: kSecMatchLimitOne)
    let kSecAttrAccessControlValue = NSString(format: kSecAttrAccessControl)
    let kSecUseOperationPromptValue = NSString(format: kSecUseOperationPrompt)

    // set access control
    let accessControl = SecAccessControlCreateWithFlags(kCFAllocatorDefault,
        kSecAttrAccessibleWhenPasscodeSetThisDeviceOnly, .UserPresence, nil)
    // Instantiate a new default keychain query
    // Tell the query to return a result
    // Limit our results to one item
    var keychainQuery: NSMutableDictionary = NSMutableDictionary(objects: [kSecClassGenericPasswordValue, service, userAccount, kCFBooleanTrue, kSecMatchLimitOneValue, "Place your finger to authenticate.", accessControl.takeUnretainedValue()], forKeys: [kSecClassValue, kSecAttrServiceValue, kSecAttrAccountValue, kSecReturnDataValue, kSecMatchLimitValue, kSecUseOperationPromptValue, kSecAttrAccessControlValue])

    var dataTypeRef :Unmanaged<AnyObject>?

    // Search for the keychain item
    touchIdStatusCode = SecItemCopyMatching(keychainQuery, &dataTypeRef)

这是生成的keychainQuery字典:
{
    "accc" = "<SecAccessControlRef: 0x170621140>";
    "acct" = “MY_ACCOUNT”;
    "class" = genp;
    "m_Limit" = "m_LimitOne";
    "r_Data" = 1;
    "svce" = “MY_SERVICE”;
    "u_OpPrompt" = "Place your finger to authenticate.";
}

最新的iOS版本(8.4)上存在此行为。这是我指的屏幕:
ios - 带有KeyChain的TouchID-输入密码屏幕显示格式不正确(快速)-LMLPHP

我的问题是:我是否因调用TouchID导致屏幕破裂?还是在这种情况下完全正常?

谢谢,对不起,冗长的帖子!

最佳答案

所描述的问题是Apple工程师确认的错误。从iOS 9.0.2开始它仍然存在。

09-20 22:52