【发布时间】:2025-12-05 14:25:01
【问题描述】:
我正在开发一个 iOS 应用程序,我想实施 ECDH 以确保安全。 我使用这个应用程序(https://github.com/DigitalLeaves/AsymmetricCrypto)生成一对密钥(私钥和公钥),使用:
private let kAsymmetricCryptoManagerKeyType = kSecAttrKeyTypeEC
private let kAsymmetricCryptoManagerKeySize = 256
private let kAsymmetricCryptoManagerCypheredBufferSize = 128
private let kAsymmetricCryptoManagerSecPadding: SecPadding = .PKCS1
所以,我可以将私钥和公钥作为字符串获取如下:
private key :3b3aef4e27c61e376bb1440f6a3077199d6d5ec665f6cd3595483a05ed96c498
public key X :3a405b5877d2939aea9dfb2995a89f4d63fca3c0cbb2a9d066fe67a08c499163
public key Y : 69bdbfc0ddea97ee03e85eb335db589cfcbee54b71f7fd74f6bc7344b5539ed6
效果很好。
现在,我想要的是执行 ECDH 以在我生成的私钥和我(从另一个平台)获得的公钥之间生成一个共享密钥,如字符串:
X: b1a2166411655482ad39630a480768dde4ccce5af4c53edec82496f17f0ddbfd
Y: e6dd01508da28f4f2295d9fee86239f88e8c5cbc94dbbb1f814b27c85d0d971a
所以第一个问题是如何将这最后两行字符串转换成一个SecKey来产生一个公钥。
第二个问题是如何在我生成的私钥(作为 SecKey)和我想在第一个问题中获得的新公钥之间执行 ECDH。
这是我用来生成密钥对的一些代码:
func createSecureKeyPair(_ completion: ((_ success: Bool, _ error: AsymmetricCryptoException?) -> Void)? = nil) {
// private key parameters
let privateKeyParams: [String: AnyObject] = [
kSecAttrIsPermanent as String: true as AnyObject,
kSecAttrApplicationTag as String: kAsymmetricCryptoManagerApplicationTag as AnyObject
]
//public key parameters
let publicKeyParams: [String: AnyObject] = [
kSecAttrIsPermanent as String: true as AnyObject,
kSecAttrApplicationTag as String: kAsymmetricCryptoManagerApplicationTag as AnyObject
]
// global parameters for our key generation
let parameters: [String: AnyObject] = [
kSecAttrKeyType as String: kAsymmetricCryptoManagerKeyType,
kSecAttrKeySizeInBits as String: kAsymmetricCryptoManagerKeySize as AnyObject,
kSecPublicKeyAttrs as String: publicKeyParams as AnyObject,
kSecPrivateKeyAttrs as String: privateKeyParams as AnyObject,
]
// asynchronously generate the key pair and call the completion block
DispatchQueue.global(qos: DispatchQoS.QoSClass.default).async { () -> Void in
var pubKey, privKey: SecKey?
let status = SecKeyGeneratePair(parameters as CFDictionary, &pubKey, &privKey)
print("pub :",pubKey)
我想在这个网站上共享一个秘密:http://www-cs-students.stanford.edu/~tjw/jsbn/ecdh.html with secp256r1 parameteres
提前致谢。
【问题讨论】:
-
这个答案有什么解决方案吗?
-
是的,我使用 SwCrypt (github.com/soyersoyer/SwCrypt) 来解决我的问题。
-
你是如何使用 SwCrypt 从原始字符串中获取密钥的?你能分享你的代码吗?谢谢!
-
你得到答案了吗?
标签: ios swift key elliptic-curve