我有一个以 HTTP cookie 形式从 Web 服务收到的身份验证令牌。目前,我依赖于 iOS 的默认行为,即将从 HTTP 请求返回的 cookie 存储在NSHTTPCookieStorage
保留 cookie 直到用户关闭应用程序的对象。
但是,我想在钥匙串中的应用程序生命周期之间保留 cookie,以便当用户重新打开应用程序时,如果他们的 cookie 没有过期,他们将不需要再次登录。似乎没有一种简单的方法可以将通用对象存储到钥匙串中,因此似乎最好的途径是序列化通过检索的字典对象NSHTTPCookie
's property
到一个字符串并将其存储在钥匙串中。然后我可以通过重建cookieinitWithProperties
构造函数在NSHTTPCookie
并将其放回NSHTTPCookieStorage
object.
在 Swift 中做到这一点最简单的方法是什么?我发现苹果编写的名为“KeychainItemWrapper”的代码,但它的文档非常参差不齐,而且它似乎是为了存储用户的电子邮件(或用户名)和密码而设计的,而不是通用对象。是否有更简单的方法来使用钥匙串,或者有更好的方法来安全地存储 Web 服务的身份验证令牌?
您应该检查 SSKeychain:https://github.com/soffes/sskeychain https://github.com/soffes/sskeychain。它在钥匙串 API 上有一个非常漂亮且可用的界面。
它本身不是 Swift,但您仍然应该能够在 Swift 应用程序中使用它。我认为没有办法存储对象本身,但正如您提到的,您可以将 cookie 序列化为字符串并将其保存在钥匙串中。
下面的示例说明了如何使用它。
NSString * const LoginService = @"com.example.loginService"; // unique identifier shared across your apps to identify various services your app may provide that require the keychain
NSString *cookie = // cookie string
NSString *userAccountIdentifier = // could be an email, username, id, or some other way to uniquely identify the user
[SSKeychain setPassword:cookie forService:LoginService account:userAccountIdentifier error:&error];
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)