3

我使用RSACryptoServiceProvider创建了一个公钥/私钥并将其保存为 XML。我可以使用它来加密/解密/签名和验证 .NET 中的数据。

我有另一个旨在在 Linux 服务器上运行的应用程序。我正在用 C++ 开发它,我正在使用 Crypto++ 来满足我的密码学需求。

我想在这两个应用程序之间共享数据,但要做到这一点,我需要将 RSAParameters 转换为 Crypto++ 可以理解的公钥/私钥。

如果这样做更容易,我也愿意使用将 Crypto++ 生成的公钥/私钥转换为 RSAParameters。

有任何想法吗?

4

1 回答 1

2

最简单的方法可能是直接使用 RSAParameters 而不是通过 XML。

只需使用您自己选择的格式将包含在 RSAParameters 中的字节数组存储在文件中。在 C++ 程序中读回字节数组并从中创建CryptoPP::Integer。使用这些整数来初始化RSAFunction(公钥)或InvertibleRSAFunction (私钥)。

反向方式类似:即

RSAFunction publicKey = ...;

size_t modulusLength = publicKey.getModulus().ByteCount();
unsigned char * modulus = new unsigned char[modulusLength];
publicKey.getModulus().Encode(modulus, modulusLength);

// similarly with PublicExponent and remember to clean up the arrays.

并将数组传输到您的 .NET 应用程序,您可以在其中使用它们来初始化 RSAParameters。

于 2009-05-28T19:25:44.850 回答