我在这方面遇到了困难:
我们的应用程序使用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)上存在此行为。这是我指的屏幕:
我的问题是:我是否因调用TouchID导致屏幕破裂?还是在这种情况下完全正常?
谢谢,对不起,冗长的帖子!
最佳答案
所描述的问题是Apple工程师确认的错误。从iOS 9.0.2开始它仍然存在。