5

任何人都可以解释 RSAParameters 的参数我见过像 p,d,e,q,... 这样的参数我需要它的私钥和公钥

我得到了链接

http://msdn.microsoft.com/en-us/library/system.security.cryptography.rsaparameters%28v=vs.90%29.aspx[^]

我正在使用示例代码,任何人都可以说它是正确的还是错误的示例代码:

  //Generate a public/private key pair.
            RSACryptoServiceProvider RSA = new RSACryptoServiceProvider();
            //Save the public key information to an RSAParameters structure.
            RSAParameters RSAKeyInfo = RSA.ExportParameters(true);
            //public key    
            TextBox5.Text = Convert.ToBase64String(RSAKeyInfo.Exponent);
            // private key  
            TextBox6.Text = Convert.ToBase64String(RSAKeyInfo.D);

他们给出的公钥是 {e,n} 其中 n = (P*Q) 的结果 私钥是 {d, n} 其中 n = (P*Q) 的结果

在公钥和私钥的示例代码中,我所做的是否正确

多谢

4

1 回答 1

11

使用 BouncyCastle API

http://www.bouncycastle.org/

以及类似于以下内容:

public AsymmetricCipherKeyPair GenerateKeys(int keySizeInBits)
{
  RsaKeyPairGenerator r = new RsaKeyPairGenerator();
  r.Init(new KeyGenerationParameters(new SecureRandom(),
    keySizeInBits));
  AsymmetricCipherKeyPair keys = r.GenerateKeyPair();
  return keys;
}

您可以访问将具有 . Public和 。Private具有正确格式的字符串的属性。

不久前我遇到了类似的问题,这是我能找到的最佳解决方案。我手头没有确切的代码,但如果需要,我会在我进入办公室时发布它,但上面应该可以工作。

用代码更新

这是我用来生成公钥/私钥的代码。

  using Org.BouncyCastle.Crypto;
  using Org.BouncyCastle.Crypto.Generators;
  using Org.BouncyCastle.Security;

  public static AsymmetricCipherKeyPair GenerateKeys(int keySizeInBits)
    {
        var r = new RsaKeyPairGenerator();
        r.Init(new KeyGenerationParameters(new SecureRandom(),keySizeInBits));
        var keys = r.GenerateKeyPair();
        return keys;
    }



static void Main(string[] args)
{
    var keys = GenerateKeys(2048);


    var publicKey = keys.Public.ToString();

    var textWriter = new StreamWriter("private.key");
    var pemWriter = new PemWriter(textWriter);
    pemWriter.WriteObject(keys.Private);
    pemWriter.Writer.Flush();
    textWriter.Close();


    textWriter = new StreamWriter("public.key");
    pemWriter = new PemWriter(textWriter);
    pemWriter.WriteObject(keys.Public);
    pemWriter.Writer.Flush();
    textWriter.Close();

    Console.ReadKey();


}
于 2011-06-30T07:04:46.460 回答