首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Swift中的ECIES加密与EC密钥生成

Swift中的ECIES加密与EC密钥生成
EN

Stack Overflow用户
提问于 2022-04-06 14:47:28
回答 2查看 239关注 0票数 0

后端使用这个java实现来使用公钥加密数据(从iOS应用程序中生成),

代码语言:javascript
复制
        Cipher iesCipher = Cipher.getInstance("ECIESwithAES-CBC");
        byte[] derivation = Hex.decode(derivationString);
        byte[] encoding = Hex.decode(encodingString);
        byte[] nonce = Hex.decode(nonceString);
        IESParameterSpec params = new IESParameterSpec(derivation, encoding, 128, 128, nonce, true);
        iesCipher.init(Cipher.ENCRYPT_MODE, publicKey, params);
        byte[] ciphertext = iesCipher.doFinal(data.getBytes());

但在迅捷中,我找不到任何等效的库来解密它。我正在使用SwiftECC生成EC密钥对,并将公钥发送到服务器。然后,服务器使用上述实现代码中提到的公钥对数据进行加密。但是SwiftECC没有任何解密函数来接受像派生、编码、现在这样的参数。我也找不到与上面的java实现类似的东西。

EN

Stack Overflow用户

发布于 2022-04-06 19:35:01

我已经在EllipticCurveKit中实现了ECIES,可以随意使用它作为灵感。如果您不想使用SwiftECC EC实现,应该可以将其移植到EllipticCurveKits。

我已经将曲线硬编码为Secp256k1 (又称“比特币曲线”),但是您可以很容易地通过传递泛型曲线类型来更改它:

代码语言:javascript
复制
func seal<Plaintext>(
    _ message: Plaintext,
    whitePublicKey: PublicKey<Secp256k1>,
    blackPrivateKey: PrivateKey<Secp256k1>,
    nonce: SealedBox.Nonce? = nil
) -> Result<SealedBox, EncryptionError> where Plaintext: DataProtocol

into (它应该在EllipticCurveKit中工作,在其他EC库中也应该是可能的):

代码语言:javascript
复制
func seal<Plaintext, Curve>(
    _ message: Plaintext,
    whitePublicKey: PublicKey<Curve>,
    blackPrivateKey: PrivateKey<Curve>,
    nonce: SealedBox.Nonce? = nil
) -> Result<SealedBox, EncryptionError> where Plaintext: DataProtocol, Curve: EllipticCurve
票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71768906

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档