首页 > 解决方案 > 私人钥匙串商店

问题描述

我们有一个企业 iOS SDK,它使用 Keychain 来存储高度敏感的信息。这些信息对客户端的应用程序不可用。

我一直认为您需要一个密钥来从钥匙串中获取关联的值。但最近,我发现你可以让 Keychain 返回 Keychain 中存储的所有密钥(恕我直言,这是一个糟糕的设计)。

由于客户端的应用程序可以轻松获取所有 Keychain 元素,我真的很想为 SDK 创建一个单独的 Keychain 存储。我已经查看了 SO 问题,但从未找到答案。

TL;DR:如何在 iOS 中创建单独的钥匙串商店?

标签: ioskeychain

解决方案


你不能。

KeyChain 的安全边界是应用程序(如果您启用 KeyChain 共享,则为来自同一开发人员的多个应用程序的 KeyChain 标识符)。

一旦您的框架嵌入到客户端应用程序中,它就是客户端应用程序的一部分。它没有自己的上下文或进程空间或任何将其代码与客户端代码区分开来的东西。

如果你的框架中的代码在 KeyChain 中放置了一些东西,那么对于 iOS,它是客户端应用程序在 KeyChain 中放置了一些东西,并且没有理由对其自身保密。

即使您可以仅为您的框架创建一个 KeyChain,也可能将信息放入 KeyChain 的代码在您的框架中,因此攻击者可以通过反编译您的框架来获取信息。


推荐阅读