问题描述
我的应用将用户的许可证密钥存储为钥匙串项目。
我过去已将 kSecAttrAccessible
属性设置为 kSecAttrAccessibleAlwaysThisDeviceOnly
,但由于 iOS 12 中已弃用此属性,我现在想在最新的应用更新中将其更改为 kSecAttrAccessibleAfterFirstUnlockThisDeviceOnly
。
使用新属性写入的钥匙串项目可以使用新属性读取。使用旧属性在旧应用版本中编写的钥匙串项目无法使用新属性读取 - SecItemcopyMatching()
返回 errSecItemNotFound
。
它确实可以反过来工作:可以使用 kSecAttrAccessibleAfterFirstUnlockThisDeviceOnly
读取使用 kSecAttrAccessibleAlwaysThisDeviceOnly
属性写入钥匙串的项目。
这是预期的行为吗?有没有比使用中间清理例程删除和重写钥匙串条目更优雅的方法来摆脱弃用?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)