使用先前生成的带有.net框架的RSA公钥/私钥

时间:2009-10-07 00:41:51

标签: c# .net security encryption rsa

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

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(...)

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

有谁知道如何完成我想要做的事情? 任何帮助将不胜感激。

干杯 那仁

2 个答案:

答案 0 :(得分:3)

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

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

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

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

答案 1 :(得分:0)

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

现在,您可以以XML格式检索/存储密钥(您可能也可以在以后的日子里找回)。

示例导入:

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

示例导出:

this.RSAKey_XMLString = RSA.ToXmlString(includePrivateParameters: false);