8

我有一个预先存在的用于 RSA 加密的公钥/私钥对,我需要在 .net 中使用它。我可以在网上找到的所有示例都演示了如何生成新的私有/公共对然后加密/解密。IE。像这样的东西:

const int PROVIDER_RSA_FULL = 1;
const string CONTAINER_NAME = "SpiderContainer";
CspParameters cspParams;
cspParams = new CspParameters(PROVIDER_RSA_FULL);
cspParams.KeyContainerName = CONTAINER_NAME;
cspParams.Flags = CspProviderFlags.UseMachineKeyStore;
cspParams.ProviderName = "Microsoft Strong Cryptographic Provider";
rsa = new RSACryptoServiceProvider(cspParams);
.....
rsa.encrypt(...)
rsa.decrypt(...)

可以看出,没有指定预先存在的公钥/私钥的途径。

有人知道如何完成我想要做的事情吗?任何帮助将非常感激。

干杯纳伦

4

2 回答 2

5

要使用现有密钥,您可以使用ImportParameters- 方法:

RSAParameters parameters = new RSAParameters()
parameters.Modulus = // ...
parameters.Exponent = // ...
RSA rsa = new RSACryptoServiceProvider();
rsa.ImportParameters(parameters);
rsa.Encrypt(/*...*/);

您也可以添加私有参数,以便将其用于解密或签名。

为了告诉您如何从现有的 keydata 中获取参数,我们需要确切地知道它们是如何编码的。尝试向我们展示字符串(如果它是真正的密钥,则用 Xs 替换大部分私钥)。

于 2009-10-08T15:44:48.317 回答
0

我意识到这是一个非常古老的问题,但也许有人仍然在看这个......

如今,您可以以 XML 格式检索/存储您的密钥(您也可以在过去使用这种格式)。

导入示例:

this.RSAKey = RSA.FromXmlString(xmlString: myRSAXMLKey);

导出示例:

this.RSAKey_XMLString = RSA.ToXmlString(includePrivateParameters: false);
于 2014-11-18T15:17:07.050 回答