1

作为基于 Swift 的 PKI 实现的一部分,我将 SecKeyWrapper.m 移植到 Swift

除了 Swift 实现中的一部分外,Keychain 访问方法(Objective-C 和 Swift)都运行良好。

我从对等方收到 base64 格式的公钥。它被转换为 NSData,然后使用以下方法保存在 Keychain 中:

statusCode = SecItemAdd(queryDictionary, &persistentPeer)

成功将对等公钥保存在钥匙串中后,我需要将其作为 SecKeyRef 获取。

    queryDictionary[kSecReturnPersistentRef] = true
    var peerKeyRef: AnyObject?
    statusCode = SecItemCopyMatching(queryDictionary, &peerKeyRef)

问题是 SecItemCopyMatching 返回一个 AnyObject 类型的对象?不能转换为 SecKeyRef (或 SecKey 那是别名)

let key = peerKeyRef as? SecKeyRef // Compile error.

我发现的解决方法是将 peerKeyRef 转换为 NSObject?然后使用 Objective-C 桥接到 SecKey,如下所示:

let keyObject = peerKeyRef as? NSObject
keyRef = Utility.getSecKeyRefFromAnyObject(keyObject).takeRetainedValue()

执行此操作的 Objetive-C 代码如下:

+(SecKeyRef) getSecKeyRefFromNSObject:(id)theObject {
    return (__bridge SecKeyRef)theObject;
}

使用此解决方法转换为 SecKey 可以正常工作(没有警告或错误)并具有预期的结果。

你认为 Swift 代码中缺少什么来转换 AnyObject?到 SecKeyRef?

我正在使用 Xcode 7.3.1 和 Swift 2.2

rgds....

4

1 回答 1

1

那个编译错误对我来说似乎是一个错误。(当所有 CF 类型都作为类型别名导入时,这曾经是一个有效的诊断AnyObject。)

但在你的情况下,我会这样做:

let key = peerKeyRef as! SecKeyRef?

您 100% 确定查询返回SecKeyRefor nil,不是吗?

于 2016-08-01T20:46:51.143 回答