Sample code for 30+ languages & platforms
C#

Generate an RSA Key and Get as Base64 DER

See more RSA Examples

Demonstrates how to generate a 2048-bit RSA key and return the public and private parts as unencrypted Base64 encoded DER.

Chilkat C# Downloads

C#
bool success = false;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

Chilkat.Rsa rsa = new Chilkat.Rsa();

// Generate a 2048-bit key.
Chilkat.PrivateKey privKey = new Chilkat.PrivateKey();
success = rsa.GenKey(2048,privKey);
if (success == false) {
    Debug.WriteLine(rsa.LastErrorText);
    return;
}

// Get the public part of the key.
Chilkat.PublicKey pubKey = new Chilkat.PublicKey();
privKey.ToPublicKey(pubKey);

// There are two possible formats for representing the RSA public key 
// in ASN.1 (DER).  The possible formats are PKCS1 and PKCS8.
// We can get either by setting bChoosePkcs1 to true or false.
bool bChoosePkcs1 = true;
string pubKeyBase64Der = pubKey.GetEncoded(bChoosePkcs1,"base64");
Debug.WriteLine("Public Key Base64 DER:");
Debug.WriteLine(pubKeyBase64Der);

// Get the private key as Base64 DER:
// We can get PKCS1 or PKCS8, but with different methods:
string privKeyPkcs1 = privKey.GetPkcs1ENC("base64");
Debug.WriteLine("Private Key PKCS1 Base64 DER:");
Debug.WriteLine(privKeyPkcs1);

string privKeyPkcs8 = privKey.GetPkcs8ENC("base64");
Debug.WriteLine("Private Key PKCS8 Base64 DER:");
Debug.WriteLine(privKeyPkcs8);